**CONTROLLER MANUAL** 

# F<sup>2</sup>MC<sup>TM</sup>-16LX 16-BIT MICROCONTROLLER MB90360 Series HARDWARE MANUAL



# F<sup>2</sup>MC<sup>TM</sup>-16LX 16-BIT MICROCONTROLLER MB90360 Series HARDWARE MANUAL

# **PREFACE**

# ■ Objectives and intended reader

Thank you very much for your continued patronage of Fujitsu semiconductor products.

The MB90360 series has been developed as a general-purpose version of the  $F^2MC-16LX$  family, which is an original 16-bit single-chip microcontroller compatible with the Application Specific IC (ASIC).

This manual explains the functions and operation of the MB90360 series for engineers who actually use the MB90360 series to design products. Please read this manual first.

### ■ Trademark

F<sup>2</sup>MC, an abbreviation of FUJITSU Flexible Microcontroller, is a registered trademark of FUJITSU Ltd

Embedded Algorithm is a registered trademark of Advanced Micro Devices Inc.

# ■ Structure of this preliminary manual

This manual contains the following 26 chapters and appendix.

#### **CHAPTER 1 OVERVIEW**

The MB90360 Series is a family member of the F<sup>2</sup>MC-16LX micro controllers.

# **CHAPTER 2 CPU**

This chapter explains the CPU.

#### **CHAPTER 3 INTERRUPTS**

This chapter explains the interrupts and function and operation of the extended intelligent I/O service in the MB90360 series.

# **CHAPTER 4 DELAYED INTERRUPT GENERATION MODULE**

This chapter explains the functions and operations of the delayed interrupt generation module.

# **CHAPTER 5 CLOCKS**

This chapter explains the clocks used by MB90360 series microcontrollers.

#### **CHAPTER 6 CLOCK SUPERVISOR**

This chapter explains the function and the operation of the clock supervisor. Only the product with built-in clock supervisor of the MB90360 series is valid to this function.

# **CHAPTER 7 RESETS**

This chapter describes resets for the MB90360-series microcontrollers.

#### **CHAPTER 8 LOW-POWER CONSUMPTION MODE**

This chapter explains the low-power consumption mode of MB90360 series microcontrollers.

#### **CHAPTER 9 MEMORY ACCESS MODES**

This chapter explains the functions and operations of the memory access modes.

#### **CHAPTER 10 I/O PORTS**

This chapter explains the functions and operations of the I/O ports.

#### **CHAPTER 11 TIMEBASE TIMER**

This chapter explains the functions and operations of the timebase timer.

#### **CHAPTER 12 WATCHDOG TIMER**

This chapter describes the function and operation of the watchdog timer.

# CHAPTER 13 16-Bit I/O TIMER

This chapter explains the function and operation of the 16- bit I/O timer.

#### **CHAPTER 14 16-BIT RELOAD TIMER**

This chapter describes the functions and operation of the 16-bit reload timer.

# **CHAPTER 15 WATCH TIMER**

This chapter describes the functions and operations of the watch timer.

#### **CHAPTER 16 8-/16-BIT PPG TIMER**

This chapter describes the functions and operations of the 8-/16-bit PPG timer.

#### **CHAPTER 17 DTP/EXTERNAL INTERRUPTS**

This chapter explains the functions and operations of DTP/external interrupt.

#### **CHAPTER 18 8-/10-BIT A/D CONVERTER**

This chapter explains the functions and operation of 8-/10-bit A/D converter.

### CHAPTER 19 LOW VOLTAGE DETECTION/CPU OPERATING DETECTION RESET

This chapter explains the function and operating the low voltage detection/CPU operating detection reset. This function can use only the product with "T" suffix of MB90360 series.

#### **CHAPTER 20 LIN-UART**

This chapter explains the functions and operation of LIN-UART.

# **CHAPTER 21 CAN CONTROLLER**

This chapter explains the functions and operations of the CAN controller.

# **CHAPTER 22 ADDRESS MATCH DETECTION FUNCTION**

This chapter explains the address match detection function and its operation.

#### **CHAPTER 23 ROM MIRRORING MODULE**

This chapter describes the functions and operations of the ROM mirroring function select module.

#### **CHAPTER 24 512K-BIT FLASH MEMORY**

This chapter explains the functions and operation of the 512K-bit flash memory. The following three methods are available for writing data to and erasing data from the flash memory:

- Parallel programmer
- Serial programmer
- Executing programs to write/erase data

This chapter explains "Executing programs to write/erase data".

# CHAPTER 25 EXAMPLES OF MB90F362/T(S), MB90F367/T(S) SERIAL PROGRAMMING CONNECTION

This chapter shows an example of a serial programming connection using the AF220/AF210/AF120/AF110 Flash Micro-computer Programmer by Yokogawa Digital Computer Corporation when the AF220/AF210/AF120/AF110 flash serial microcontroller programer from Yokogawa Digital Computer Corporation is used.

# **CHAPTER 26 ROM SECURITY FUNCTION**

This chapter explains the ROM security function.

# **APPENDIX**

The appendixes provide I/O maps, instructions, and other information.

- The contents of this document are subject to change without notice.
   Customers are advised to consult with FUJITSU sales representatives before ordering.
- The information, such as descriptions of function and application circuit examples, in this document are presented solely for the purpose of reference to show examples of operations and uses of Fujitsu semiconductor device; Fujitsu does not warrant proper operation of the device with respect to use based on such information. When you develop equipment incorporating the device based on such information, you must assume any responsibility arising out of such use of the information. Fujitsu assumes no liability for any damages whatsoever arising out of the use of the information.
- Any information in this document, including descriptions of function and schematic diagrams, shall not be
  construed as license of the use or exercise of any intellectual property right, such as patent right or
  copyright, or any other right of Fujitsu or any third party or does Fujitsu warrant non-infringement of any
  third-party's intellectual property right or other right by using such information. Fujitsu assumes no
  liability for any infringement of the intellectual property rights or other rights of third parties which would
  result from the use of information contained herein.
- The products described in this document are designed, developed and manufactured as contemplated for general use, including without limitation, ordinary industrial use, general office use, personal use, and household use, but are not designed, developed and manufactured as contemplated (1) for use accompanying fatal risks or dangers that, unless extremely high safety is secured, could have a serious effect to the public, and could lead directly to death, personal injury, severe physical damage or other loss (i.e., nuclear reaction control in nuclear facility, aircraft flight control, air traffic control, mass transport control, medical life support system, missile launch control in weapon system), or (2) for use requiring extremely high reliability (i.e., submersible repeater and artificial satellite).
  - Please note that Fujitsu will not be liable against you and/or any third party for any claims or damages arising in connection with above-mentioned uses of the products.
- Any semiconductor devices have an inherent chance of failure. You must protect against injury, damage
  or loss from such failures by incorporating safety design measures into your facility and equipment such
  as redundancy, fire protection, and prevention of over-current levels and other abnormal operating
  conditions.
- If any products described in this document represent goods or technologies subject to certain restrictions on export under the Foreign Exchange and Foreign Trade Law of Japan, the prior authorization by Japanese government will be required for export of those products from Japan.

# **CONTENTS**

| CHAPTE | R 1 OVERVIEW                                                                                        | . 1 |
|--------|-----------------------------------------------------------------------------------------------------|-----|
| 1.1    | Overview of MB90360                                                                                 | 2   |
| 1.2    | Block Diagram of MB90360 series                                                                     | 9   |
| 1.3    | Package Dimensions                                                                                  | 12  |
| 1.4    | Pin Assignment                                                                                      | 13  |
| 1.5    | Pin Functions                                                                                       | 14  |
| 1.6    | Input-Output Circuits                                                                               | 17  |
| 1.7    | Handling Device                                                                                     | 21  |
| CHAPTE | ER 2 CPU                                                                                            | 27  |
| 2.1    | Outline of the CPU                                                                                  | 28  |
| 2.2    | Memory Space                                                                                        | 29  |
| 2.3    | Memory Map                                                                                          | 32  |
| 2.4    | Linear Addressing                                                                                   | 33  |
| 2.5    | Bank Addressing Types                                                                               | 34  |
| 2.6    | Multi-byte Data in Memory Space                                                                     | 36  |
| 2.7    | Registers                                                                                           | 37  |
| 2.7.1  | Accumulator (A)                                                                                     | 40  |
| 2.7.2  | User Stack Pointer (USP) and System Stack Pointer (SSP)                                             | 41  |
| 2.7.3  | Processor Status (PS)                                                                               | 42  |
| 2.7.4  | Program Counter (PC)                                                                                | 45  |
| 2.8    | Register Bank                                                                                       | 46  |
| 2.9    | Prefix Codes                                                                                        | 48  |
| 2.10   | Interrupt Disable Instructions                                                                      | 51  |
| 2.11   | Precautions for Use of "DIV A, Ri" and "DIVW A, RWi" Instructions                                   | 52  |
| CHAPTE | ER 3 INTERRUPTS                                                                                     | 55  |
| 3.1    | Outline of Interrupts                                                                               | 56  |
| 3.2    | Interrupt Vector                                                                                    | 59  |
| 3.3    | Interrupt Control Registers (ICR)                                                                   | 61  |
| 3.4    | Interrupt Flow                                                                                      | 65  |
| 3.5    | Hardware Interrupts                                                                                 | 67  |
| 3.5.1  | Hardware Interrupt Operation                                                                        | 68  |
| 3.5.2  | Occurrence and Release of Hardware Interrupt                                                        | 69  |
| 3.5.3  | Multiple interrupts                                                                                 | 71  |
| 3.6    | Software Interrupts                                                                                 | 72  |
| 3.7    | Extended Intelligent I/O Service (EI <sup>2</sup> OS)                                               | 74  |
| 3.7.1  | Extended Intelligent I/O Service Descriptor (ISD)                                                   | 76  |
| 3.7.2  | EI <sup>2</sup> OS Status Register (ISCS)                                                           | 78  |
| 3.8    | Operation Flow of and Procedure for Using the Extended Intelligent I/O Service (EI <sup>2</sup> OS) | 79  |
| 3.9    | Exceptions                                                                                          | 82  |

| CHAPT | TER 4 DELAYED INTERRUPT GENERATION MODULE                               | 83  |
|-------|-------------------------------------------------------------------------|-----|
| 4.1   | Overview of Delayed Interrupt Generation Module                         | 84  |
| 4.2   | Block Diagram of Delayed Interrupt Generation Module                    |     |
| 4.3   | Configuration of Delayed Interrupt Generation Module                    |     |
| 4.3.  | · · · · · · · · · · · · · · · · · · ·                                   |     |
| 4.4   | Explanation of Operation of Delayed Interrupt Generation Module         |     |
| 4.5   | Precautions when Using Delayed Interrupt Generation Module              |     |
| 4.6   | Program Example of Delayed Interrupt Generation Module                  |     |
| СНАРТ | TER 5 CLOCKS                                                            | 91  |
| 5.1   | Clocks                                                                  | 92  |
| 5.2   | Block Diagram of the Clock Generation Block                             | 95  |
| 5.2.  | 1 Register of Clock Generation Block                                    | 97  |
| 5.3   | Clock Selection Register (CKSCR)                                        | 98  |
| 5.4   | PLL/Subclock Control Register (PSCCR)                                   | 101 |
| 5.5   | Clock Mode                                                              | 103 |
| 5.6   | Oscillation Stabilization Wait Interval                                 | 107 |
| 5.7   | Connection of an Oscillator or an External Clock to the Microcontroller | 108 |
| СНАРТ | TER 6 CLOCK SUPERVISOR                                                  | 109 |
| 6.1   | Overview of Clock Supervisor                                            | 110 |
| 6.2   | Block Diagram of Clock Supervisor                                       | 111 |
| 6.3   | Clock Supervisor Control Register (CSVCR)                               | 113 |
| 6.4   | Operating Mode of Clock Supervisor                                      | 115 |
| СНАРТ | TER 7 RESETS                                                            | 119 |
| 7.1   | Resets                                                                  | 120 |
| 7.2   | Reset Cause and Oscillation Stabilization Wait Times                    | 123 |
| 7.3   | External Reset Pin                                                      | 125 |
| 7.4   | Reset Operation                                                         | 126 |
| 7.5   | Reset Cause Bits                                                        | 128 |
| 7.6   | Status of Pins in a Reset                                               | 132 |
| СНАРТ | TER 8 LOW-POWER CONSUMPTION MODE                                        | 133 |
| 8.1   | Overview of Low-Power Consumption Mode                                  | 134 |
| 8.2   | Block Diagram of the Low-Power Consumption Control Circuit              | 137 |
| 8.3   | Low-Power Consumption Mode Control Register (LPMCR)                     | 139 |
| 8.4   | CPU Intermittent Operation Mode                                         |     |
| 8.5   | Standby Mode                                                            | 143 |
| 8.5.  | •                                                                       |     |
| 8.5.  | ·                                                                       |     |
| 8.5.  |                                                                         |     |
| 8.5.  |                                                                         |     |
| 8.6   | Status Change Diagram                                                   |     |
| 8.7   | Status of Pins in Standby Mode and during Hold and Reset                |     |
| 8.8   | Usage Notes on Low-Power Consumption Mode                               |     |

| CHAP | TER 9 MEMORY ACCESS MODES                             | 161        |
|------|-------------------------------------------------------|------------|
| 9.1  | Outline of Memory Access Modes                        | 162        |
| 9.1. | 1.1 Mode Pins                                         | 163        |
| 9.1. | 1.2 Mode Data                                         | 164        |
| 9.1. | 1.3 Memory Space in Each Bus Mode                     | 165        |
| CHAP | TER 10 I/O PORTS                                      | 167        |
| 10.1 | I/O Ports                                             | 168        |
| 10.2 | l/O Port Registers                                    | 169        |
| 10.2 | .2.1 Port Data Register (PDR)                         | 170        |
| 10.2 | .2.2 Port Direction Register (DDR)                    | 172        |
| 10.2 | .2.3 Pull-up Control Register (PUCR)                  | 174        |
| 10.2 | .2.4 Analog Input Enable Register (ADER)              | 175        |
| 10.2 | .2.5 Input Level Select Register                      | 176        |
| CHAP | TER 11 TIMEBASE TIMER                                 | 179        |
| 11.1 | Overview of Timebase Timer                            | 180        |
| 11.2 | Block Diagram of Timebase Timer                       | 182        |
| 11.3 | Configuration of Timebase Timer                       | 184        |
| 11.3 | .3.1 Timebase timer control register (TBTC)           | 185        |
| 11.4 |                                                       |            |
| 11.5 | Explanation of Operations of Timebase Timer Functions | 188        |
| 11.6 | ·                                                     |            |
| 11.7 | _                                                     |            |
| CHAP | TER 12 WATCHDOG TIMER                                 | 195        |
| 12.1 |                                                       |            |
| 12.2 | •                                                     |            |
| 12.3 | •                                                     |            |
|      | .3.1 Watchdog timer control register (WDTC)           |            |
| 12.4 |                                                       |            |
| 12.5 | •                                                     |            |
| 12.6 |                                                       |            |
| CHAP | TER 13 16-Bit I/O TIMER                               | 209        |
| 13.1 |                                                       |            |
| 13.2 |                                                       |            |
|      | .2.1 Block Diagram of 16-bit Free-run Timer           |            |
|      | .2.2 Block Diagram of Input Capture                   |            |
| 13.3 | • • •                                                 |            |
| 13.3 | -                                                     |            |
|      | .3.2 Timer Control Status Register (Lower) (TCCSL)    |            |
|      | .3.3 Timer Data Register (TCDT)                       |            |
|      | .3.4 Input Capture Control Status Registers (ICS)     |            |
|      | .3.5 Input Capture Register (IPCP)                    |            |
|      | .3.6 Input Capture Edge Register (ICE)                |            |
| 13.4 |                                                       |            |
| 10.7 |                                                       | ······ ∠∠1 |

| 13.5  | Explanation of Operation of 16-bit Free-run Timer   | 229 |
|-------|-----------------------------------------------------|-----|
| 13.6  | Explanation of Operation of Input Capture           | 231 |
| 13.7  | Precautions when Using 16-bit I/O Timer             | 233 |
| 13.8  | Program Example of 16-bit I/O Timer                 | 234 |
| СНАРТ | ER 14 16-BIT RELOAD TIMER                           | 237 |
| 14.1  | Overview of the 16-bit Reload Timer                 | 238 |
| 14.2  | Block Diagram of 16-bit Reload Timer                | 240 |
| 14.3  | Configuration of 16-bit Reload Timer                | 242 |
| 14.3  | 3.1 Timer Control Status Registers (High) (TMCSR:H) | 245 |
| 14.3  | 3.2 Timer Control Status Registers (Low) (TMCSR: L) | 247 |
| 14.3  | 3.3 16-bit Timer Registers (TMR)                    | 249 |
| 14.3  | 3.4 16-bit Reload Registers (TMRLR)                 | 250 |
| 14.4  | Interrupts of 16-bit Reload Timer                   | 251 |
| 14.5  | Explanation of Operation of 16-bit Reload Timer     | 252 |
| 14.5  | 5.1 Operation in Internal Clock Mode                | 254 |
| 14.5  | 5.2 Operation in Event Count Mode                   | 259 |
| 14.6  | Precautions when Using 16-bit Reload Timer          | 262 |
| 14.7  | Sample Program of 16-bit Reload Timer               | 263 |
| СНАРТ | TER 15 WATCH TIMER                                  | 267 |
| 15.1  | Overview of Watch Timer                             | 268 |
| 15.2  | Block Diagram of Watch Timer                        | 270 |
| 15.3  | Configuration of Watch Timer                        | 272 |
| 15.3  | 3.1 Watch Timer Control Register (WTC)              | 273 |
| 15.4  | Watch Timer Interrupt                               | 275 |
| 15.5  | Explanation of Operation of Watch Timer             | 276 |
| 15.6  | Program Example of Watch Timer                      | 278 |
| СНАРТ | ER 16 8-/16-BIT PPG TIMER                           | 281 |
| 16.1  | Overview of 8-/16-bit PPG Timer                     | 282 |
| 16.2  | Block Diagram of 8-/16-bit PPG Timer                |     |
| 16.2  | -                                                   |     |
| 16.2  | 2.2 Block Diagram of 8-/16-bit PPG Timer D          | 288 |
| 16.3  | Configuration of 8-/16-bit PPG Timer                |     |
| 16.3  | 3.1 PPGC Operation Mode Control Register (PPGCC)    | 292 |
| 16.3  | 3.2 PPGD Operation Mode Control Register (PPGCD)    | 294 |
| 16.3  | 3.3 PPGC/D Count Clock Select Register (PPGCD)      | 296 |
| 16.3  | 3.4 PPG Reload Registers (PRLLC/PRLHC, PRLLD/PRLHD) | 298 |
| 16.4  | Interrupts of 8-/16-bit PPG Timer                   |     |
| 16.5  | Explanation of Operation of 8-/16-bit PPG Timer     |     |
| 16.5  | ·                                                   |     |
| 16.5  | ·                                                   |     |
| 16.5  | ·                                                   |     |
|       | Precautions when Using 8-/16-bit PPG Timer          |     |

| CHAPT | ER 17 DTP/EXTERNAL INTERRUPTS                                        | 313 |
|-------|----------------------------------------------------------------------|-----|
| 17.1  | Overview of DTP/External Interrupt                                   | 314 |
| 17.2  | Block Diagram of DTP/External Interrupt                              | 315 |
| 17.3  | Configuration of DTP/External Interrupt                              | 317 |
| 17.3  | 3.1 DTP/External Interrupt Factor Register (EIRR1)                   | 319 |
| 17.3  | 3.2 DTP/External Interrupt Enable Register (ENIR1)                   | 321 |
| 17.3  | B.3 Detection Level Setting Register (ELVR1)                         | 323 |
| 17.3  | 8.4 External Interrupt Factor Select Register (EISSR)                | 325 |
| 17.4  | Explanation of Operation of DTP/External Interrupt                   | 327 |
| 17.4  | l.1 External Interrupt Function                                      | 331 |
| 17.4  | I.2 DTP Function                                                     | 332 |
| 17.5  | Precautions when Using DTP/External Interrupt                        | 333 |
| 17.6  | Program Example of DTP/External Interrupt Function                   | 335 |
| СНАРТ | ER 18 8-/10-BIT A/D CONVERTER                                        | 339 |
| 18.1  | Overview of 8-/10-bit A/D Converter                                  |     |
| 18.2  | Block Diagram of 8-/10-bit A/D Converter                             | 341 |
| 18.3  | Configuration of 8-/10-bit A/D Converter                             | 344 |
| 18.3  | 3.1 A/D Control Status Register (High) (ADCS1)                       | 346 |
| 18.3  | 3.2 A/D Control Status Register (Low) (ADCS0)                        | 349 |
| 18.3  | 3.3 A/D Data Register (ADCR0/ADCR1)                                  | 351 |
| 18.3  | 3.4 A/D Setting Register (ADSR0/ADSR1)                               | 352 |
| 18.3  | 3.5 Analog Input Enable Register (ADER5, ADER6)                      | 356 |
| 18.4  | Interrupt of 8-/10-bit A/D Converter                                 | 358 |
| 18.5  | Explanation of Operation of 8-/10-bit A/D Converter                  | 359 |
| 18.5  | 5.1 Single-shot Conversion Mode                                      | 360 |
| 18.5  | 5.2 Continuous Conversion Mode                                       | 362 |
| 18.5  | i.3 Pause-conversion Mode                                            | 364 |
| 18.5  | 5.4 Conversion Using El <sup>2</sup> OS Function                     | 366 |
| 18.5  | 5.5 A/D-converted Data Protection Function                           | 367 |
| 18.6  | Precautions when Using 8-/10-bit A/D Converter                       | 369 |
| СНАРТ | ER 19 LOW VOLTAGE DETECTION/CPU OPERATING DETECTION RESE             | ĒΤ  |
|       |                                                                      | 371 |
| 19.1  | Overview of Low Voltage/CPU Operating Detection Reset Circuit        |     |
| 19.2  | Configuration of Low Voltage/CPU Operating Detection Reset Circuit   | 374 |
| 19.3  | Low Voltage/CPU Operating Detection Reset Circuit Register           |     |
| 19.4  | Operating of Low Voltage/CPU Operating Detection Reset Circuit       | 378 |
| 19.5  | Notes on Using Low Voltage/CPU Operating Detection Reset Circuit     | 379 |
| 19.6  | Sample Program for Low Voltage/CPU Operating Detection Reset Circuit | 380 |
| СНАРТ | ER 20 LIN-UART                                                       | 381 |
| 20.1  | Overview of LIN-UART                                                 | 382 |
| 20.2  | Configuration of LIN-UART                                            | 386 |
| 20.3  | LIN-UART Pins                                                        | 391 |
| 20.4  | LIN-UART Registers                                                   | 392 |
| 20.4  | l.1 Serial Control Register (SCR)                                    | 393 |

|                                                                                                                                                                        | LIN-UART Serial Mode Register (SMR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |            |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| 20.4.3                                                                                                                                                                 | Serial Status Register (SSR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 397        |
| 20.4.4                                                                                                                                                                 | Reception and Transmission Data Register (RDR/TDR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 399        |
| 20.4.5                                                                                                                                                                 | Extended Status/Control Register (ESCR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 401        |
| 20.4.6                                                                                                                                                                 | Extended Communication Control Register (ECCR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 403        |
| 20.4.7                                                                                                                                                                 | Baud Rate Generator Register 0 and 1 (BGR0/1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 405        |
| 20.5 LI                                                                                                                                                                | N-UART Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 406        |
| 20.5.1                                                                                                                                                                 | Reception Interrupt Generation and Flag Set Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 409        |
| 20.5.2                                                                                                                                                                 | Transmission Interrupt Generation and Flag Set Timing                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 411        |
| 20.6 LI                                                                                                                                                                | N-UART Baud Rates                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 413        |
| 20.6.1                                                                                                                                                                 | Setting the Baud Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 415        |
| 20.6.2                                                                                                                                                                 | Restarting the Reload Counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 418        |
| 20.7 O                                                                                                                                                                 | peration of LIN-UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 420        |
| 20.7.1                                                                                                                                                                 | Operation in Asynchronous Mode (Op. Modes 0 and 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 422        |
| 20.7.2                                                                                                                                                                 | Operation in Synchronous Mode (Operation Mode 2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 426        |
| 20.7.3                                                                                                                                                                 | Operation with LIN Function (Operation Mode 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 429        |
| 20.7.4                                                                                                                                                                 | Direct Access to Serial Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 432        |
| 20.7.5                                                                                                                                                                 | Bidirectional Communication Function (Normal Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 433        |
| 20.7.6                                                                                                                                                                 | Master-Slave Communication Function (Multiprocessor Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 435        |
| 20.7.7                                                                                                                                                                 | LIN Communication Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 438        |
| 20.7.8                                                                                                                                                                 | Sample Flowcharts for LIN-UART in LIN communication (Operation Mode 3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 439        |
| 20.8 N                                                                                                                                                                 | otes on Using LIN-UART                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 441        |
|                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
| CHAPTER                                                                                                                                                                | 21 CAN CONTROLLER                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 443        |
|                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
| 21.1 Fe                                                                                                                                                                | eatures of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 444        |
|                                                                                                                                                                        | eatures of CAN Controllerock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |            |
| 21.2 BI                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 445        |
| 21.2 Bl<br>21.3 Li                                                                                                                                                     | ock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 445<br>446 |
| 21.2 Bl<br>21.3 Li                                                                                                                                                     | ock Diagram of CAN Controllerst of Overall Control Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |
| 21.2 Bl<br>21.3 Li<br>21.4 C                                                                                                                                           | ock Diagram of CAN Controllerst of Overall Control Registerslassifying CAN Controller Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
| 21.2 BI<br>21.3 Li<br>21.4 C<br>21.4.1                                                                                                                                 | ock Diagram of CAN Controllerst of Overall Control Registerslassifying CAN Controller Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |            |
| 21.2 Bl<br>21.3 Li<br>21.4 Cl<br>21.4.1<br>21.4.2                                                                                                                      | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |
| 21.2 BI<br>21.3 Li<br>21.4 C<br>21.4.1<br>21.4.2<br>21.4.3                                                                                                             | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |            |
| 21.2 Bl<br>21.3 Li<br>21.4 Cl<br>21.4.1<br>21.4.2<br>21.4.3<br>21.4.4                                                                                                  | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |
| 21.2 Bl<br>21.3 Li<br>21.4 Cl<br>21.4.1<br>21.4.2<br>21.4.3<br>21.4.4<br>21.4.5                                                                                        | lock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |            |
| 21.2 Bl<br>21.3 Li<br>21.4 Cl<br>21.4.1<br>21.4.2<br>21.4.3<br>21.4.4<br>21.4.5<br>21.4.6                                                                              | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC)                                                                                                                                                                                                                                                                                                                                                                                                                                    |            |
| 21.2 Bl<br>21.3 Li<br>21.4 C<br>21.4.1<br>21.4.2<br>21.4.3<br>21.4.4<br>21.4.5<br>21.4.6<br>21.4.7<br>21.4.8<br>21.4.9                                                 | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC) Bit Timing Register (BTR) Prescaler Setting by Bit Timing Register (BTR) Message Buffer Valid Register (BVALR)                                                                                                                                                                                                                                                                                                                     |            |
| 21.2 Bl<br>21.3 Li<br>21.4 C<br>21.4.1<br>21.4.2<br>21.4.3<br>21.4.4<br>21.4.5<br>21.4.6<br>21.4.7<br>21.4.8<br>21.4.9                                                 | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC) Bit Timing Register (BTR) Prescaler Setting by Bit Timing Register (BTR) Message Buffer Valid Register (BVALR) IDE Register (IDER)                                                                                                                                                                                                                                                                                                 |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11                                                                 | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC) Bit Timing Register (BTR) Prescaler Setting by Bit Timing Register (BTR) Message Buffer Valid Register (BVALR) IDE Register (IDER) Transmission Request Register (TREQR)                                                                                                                                                                                                                                                           |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11                                                                 | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC) Bit Timing Register (BTR) Prescaler Setting by Bit Timing Register (BTR) Message Buffer Valid Register (BVALR) IDE Register (IDER)                                                                                                                                                                                                                                                                                                 |            |
| 21.2 Bl 21.3 Li 21.4 C 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13                                                  | ock Diagram of CAN Controller st of Overall Control Registers lassifying CAN Controller Registers Configuration of Control Status Register (CSR) Function of Control Status Register (CSR) Correspondence between Node Status Bit and Node Status Notes on Using Bus Operation Stop Bit (HALT = 1) Last Event Indicator Register (LEIR) Receive and Transmit Error Counters (RTEC) Bit Timing Register (BTR) Prescaler Setting by Bit Timing Register (BTR) Message Buffer Valid Register (BVALR) IDE Register (IDER) Transmission Request Register (TREQR) Transmission RTR Register (TRTRR) Remote Frame Receiving Wait Register (RFWTR)                                                                                                                                                                            |            |
| 21.2 Bl 21.3 Li 21.4 C 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.14                                          | ock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.14 21.4.15                                 | ock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.14 21.4.15                                 | ock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |
| 21.2 Bl 21.3 Li 21.4 C 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.15 21.4.15 21.4.15                          | ock Diagram of CAN Controller                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.14 21.4.15 21.4.15 21.4.16 21.4.17 21.4.18 | ock Diagram of CAN Controller st of Overall Control Registers  lassifying CAN Controller Registers  Configuration of Control Status Register (CSR)  Function of Control Status Register (CSR)  Correspondence between Node Status Bit and Node Status  Notes on Using Bus Operation Stop Bit (HALT = 1)  Last Event Indicator Register (LEIR)  Receive and Transmit Error Counters (RTEC)  Bit Timing Register (BTR)  Prescaler Setting by Bit Timing Register (BTR)  Message Buffer Valid Register (BVALR)  IDE Register (IDER)  Transmission Request Register (TREQR)  Transmission RTR Register (TRTRR)  Remote Frame Receiving Wait Register (RFWTR)  Transmission Complete Register (TCANR)  Transmission Complete Register (TIER)  Reception Complete Register (RCR)  Remote Request Receiving Register (RRTRR) |            |
| 21.2 Bl 21.3 Li 21.4 Cl 21.4.1 21.4.2 21.4.3 21.4.4 21.4.5 21.4.6 21.4.7 21.4.8 21.4.9 21.4.10 21.4.11 21.4.12 21.4.13 21.4.14 21.4.15 21.4.15 21.4.16 21.4.17 21.4.18 | ock Diagram of CAN Controller st of Overall Control Registers  lassifying CAN Controller Registers  Configuration of Control Status Register (CSR)  Function of Control Status Register (CSR)  Correspondence between Node Status Bit and Node Status  Notes on Using Bus Operation Stop Bit (HALT = 1)  Last Event Indicator Register (LEIR)  Receive and Transmit Error Counters (RTEC)  Bit Timing Register (BTR)  Prescaler Setting by Bit Timing Register (BTR)  Message Buffer Valid Register (BVALR)  IDE Register (IDER)  Transmission Request Register (TREQR)  Transmission RTR Register (TRTRR)  Remote Frame Receiving Wait Register (RFWTR)  Transmission Complete Register (TCR)  Transmission Interrupt Enable Register (TIER)  Reception Complete Register (RCR)                                      |            |

|   | 21.4.20 Reception Interrupt Enable Register (RIER)                                         | . 476        |
|---|--------------------------------------------------------------------------------------------|--------------|
|   | 21.4.21 Acceptance Mask Select Register (AMSR)                                             |              |
|   | 21.4.22 Acceptance Mask Registers 0 and 1 (AMR0 and AMR1)                                  |              |
|   | 21.4.23 Message Buffers                                                                    |              |
|   | 21.4.24 ID Register x (x = 0 to 15) (IDRx)                                                 |              |
|   | 21.4.25 DLC Register x (x = 0 to 15) (DLCRx)                                               |              |
|   | 21.4.26 Data Register x (x = 0 to 15) (DTRx)                                               |              |
|   | 21.5 Transmission of CAN Controller                                                        |              |
|   | 21.6 Reception of CAN Controller                                                           |              |
|   | 21.7 Reception Flowchart of CAN Controller                                                 |              |
|   | 21.8 How to Use CAN Controller                                                             |              |
|   | 21.9 Procedure for Transmission by Message Buffer (x)                                      |              |
|   | 21.10 Procedure for Reception by Message Buffer (x)                                        |              |
|   | 21.11 Setting Configuration of Multi-level Message Buffer                                  |              |
|   | 21.12 Setting the CAN Direct Mode Register                                                 |              |
|   | 21.13 Precautions when Using CAN Controller                                                |              |
|   | 21.10 1 1000000010 Whom Coming Of the Controller                                           | . 000        |
| C | HAPTER 22 ADDRESS MATCH DETECTION FUNCTION                                                 | 505          |
|   | 22.1 Overview of Address Match Detection Function                                          |              |
|   | 22.2 Block Diagram of Address Match Detection Function                                     |              |
|   | 22.3 Configuration of Address Match Detection Function                                     |              |
|   | 22.3.1 Address Detection Control Register (PACSR0/PACSR1)                                  |              |
|   | 22.3.2 Detect Address Setting Registers (PADR0 to PADR5)                                   |              |
|   | 22.4 Explanation of Operation of Address Match Detection Function                          |              |
|   | 22.4.1 Example of using Address Match Detection Function                                   |              |
|   | 22.5 Program Example of Address Match Detection Function                                   |              |
|   |                                                                                            |              |
| C | HAPTER 23 ROM MIRRORING MODULE                                                             | 525          |
|   | 23.1 Overview of ROM Mirroring Function Select Module                                      |              |
|   | 23.2 ROM Mirroring Function Select Register (ROMM)                                         |              |
|   |                                                                                            | 020          |
| C | HAPTER 24 512K-BIT FLASH MEMORY                                                            | 529          |
|   | 24.1 Overview of 512K-bit Flash Memory                                                     |              |
|   | 24.2 Block Diagram of the Entire Flash Memory and Sector Configuration of the Flash Memory |              |
|   | 24.3 Write/Erase Modes                                                                     |              |
|   | 24.4 Flash Memory Control Status Register (FMCS)                                           |              |
|   | 24.5 Starting the Flash Memory Automatic Algorithm                                         |              |
|   | 24.6 Confirming the Automatic Algorithm Execution State                                    |              |
|   | 24.6.1 Data Polling Flag (DQ7)                                                             |              |
|   | 24.6.2 Toggle Bit Flag (DQ6)                                                               |              |
|   | 24.6.3 Timing Limit Exceeded Flag (DQ5)                                                    |              |
|   | 24.7 Detailed Explanation of Writing to and Erasing Flash Memory                           |              |
|   | 24.7.1 Setting The Read/Reset State                                                        |              |
|   | 24.7.2 Writing Data                                                                        |              |
|   | 24.7.3 Erasing All Data (Erasing Chips)                                                    |              |
|   | 24.8 Notes on Using 512K-bit Flash Memory                                                  |              |
|   | 24.9 Flash Security Feature                                                                | . 550<br>551 |
|   |                                                                                            |              |

| CHAPT | ER 25 EXAMPLES OF MB90F362/T(S), MB90F367/T(S)SERIAL PROGRAMN                                      | IING |
|-------|----------------------------------------------------------------------------------------------------|------|
|       | CONNECTION                                                                                         | 553  |
| 25.1  | Basic Configuration of Serial Programming Connection with MB90F362/T(S), MB90F367/T(S)             | 554  |
| 25.2  | Example of Serial Programming Connection (User Power Supply Used)                                  | 557  |
| 25.3  | Example of Serial Programming Connection (Power Supplied from Programmer)                          | 559  |
| 25.4  | Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply Used)         | 561  |
| 25.5  | Example of Minimum Connection to Flash Microcontroller Programmer (Power Supplied from Programmer) | 563  |
| CHAPT | ER 26 ROM SECURITY FUNCTION                                                                        |      |
| 26.1  | Overview of ROM Security Function                                                                  | 566  |
| APPEN | DIX                                                                                                | 567  |
| APPE  | NDIX A I/O Maps                                                                                    | 568  |
| APPE  | NDIX B Instructions                                                                                | 576  |
| B.1   | Instruction Types                                                                                  | 577  |
| B.2   | Addressing                                                                                         | 578  |
| B.3   | Direct Addressing                                                                                  | 580  |
| B.4   | Indirect Addressing                                                                                |      |
| B.5   | Execution Cycle Count                                                                              |      |
| B.6   | Effective address field                                                                            |      |
| B.7   | How to Read the Instruction List                                                                   |      |
| B.8   | F <sup>2</sup> MC-16LX Instruction List                                                            |      |
| B.9   | Instruction Map                                                                                    |      |
|       | NDIX C Timing Diagrams in Flash Memory Mode                                                        |      |
| APPE  | NDIX D List of Interrupt Vectors                                                                   | 644  |

# CHAPTER 1 OVERVIEW

The MB90360 Series is a family member of the F<sup>2</sup>MC-16LX micro controllers.

- 1.1 Overview of MB90360
- 1.2 Block Diagram of MB90360 series
- 1.3 Package Dimensions
- 1.4 Pin Assignment
- 1.5 Pin Functions
- 1.6 Input-Output Circuits
- 1.7 Handling Device

# 1.1 Overview of MB90360

The MB90360 Series is a 16-bit microcontroller designed for automotive applications and contains CAN function, capture, compare timer, A/D converter, and so on.

# **■** Features of MB90360 Series

MB90360 series has the following features:

# Clock

- Built-in PLL clock multiplying circuit
- Machine clock (PLL clock) selectable from 1/2 frequency of oscillation clock or 1 to 6-multiplied oscillation clock (4 MHz to 24 MHz when oscillation clock is 4 MHz)
- Subclock operation (8.192 kHz)
- Minimum instruction execution time: 42 ns (4-MHz oscillation clock and 6-multiplied PLL clock)
- · Clock supervisor: monitors main clock or subclock independently
- · Subclock mode: Clock source selectable from external oscillator or internal CR oscillator

# 16-MB CPU memory space

- Internal 24-bit addressing
- Instruction system optimized for controllers
  - Various data types (bit, byte, word, long word)
  - 23 types of addressing modes
  - Enhanced signed instructions of multiplication/division and RETI
  - High-accuracy operations enhanced by 32-bit accumulator
- Instruction system for high-level language (C language)/multi-task
  - · System stack pointer
  - Enhanced pointer indirect instructions
  - · Barrel shift instructions
- Higher execution speed
  - 4 bytes instruction queue
- Powerful interrupt function
  - Powerful interrupt function with 8 levels and 34 factors
  - Corresponds to 8-channel external interrupts

# CPU-independent automatic data transfer function

Extended intelligent I/O service (EI<sup>2</sup>OS): Maximum 16 channels

# Lower-power consumption (standby) modes

- Sleep mode (stops CPU clock)
- Timebase timer mode (operates only oscillation clock and subclock, timebase timer and watch timer)
- Watch mode (product without S-suffix operates only subclock and watch timer)
- Stop mode (stops oscillation clock and subclock)
- CPU intermittent operation mode

# Process

**CMOS** Technology

# I/O ports

- General-purpose I/O ports (CMOS output)
  - 34 ports (product without S-suffix)
  - 36 ports (product with S-suffix)

# Subclock pin (X0A, X1A)

- Yes (external oscillator used) ... products without S-suffix
- No (subclock mode is used with internal CR oscillation) ... product with S-suffix

#### Timers

- Timebase timer, watch timer (product without S-suffix), watchdog timer: 1 channel
- 8-/16-bit PPG timer: 8 bits  $\times$  4 channels or 16 bits  $\times$  2 channels
- 16-bit reload timer: 2 channels
- 16-bit I/O timer
  - 16-bit free-run timer: 1 channel (FRT0: ICU0/1/2/3)
  - 16-bit input capture (ICU): 4 channels

# Full-CAN\* CAN Controller: 1 channel

- Conforms to CAN Specification Ver. 2.0A and Ver. 2.0B.
- Built-in 16 message buffers
- · CAN wake up

# UART (LIN/SCI): Maximum 2 channels

- Full-duplex double buffer
- · Clock asynchronous or clock synchronous serial transfer

# DTP/external interrupt: 8 channels, CAN wake up: 1 channel

External input to start EI<sup>2</sup>OS and generate external interrupt

Delayed interrupt generation module

Generates interrupt request for task switching

- 8-/10-bit A/D converter: 16 channels
  - 8-bit and 10-bit resolutions
  - Start by external trigger input
  - Conversion time: 3 µs (including sampling time at 24-MHz machine clock frequency)
- Program patch function

Detects address match for six address pointers

- Low voltage/CPU operation detection reset function (product with T-suffix)
  - Detects low voltage  $(4.0 \text{ V} \pm 0.3 \text{ V})$  and reset automatically
  - Automatic reset when program runs away and counter is not cleared within internal time (approx. 262 ms @ 4 MHz external)
- Clock supervisor (MB90x367x only)
- Changeable port input voltage level

Automotive input level/CMOS Schmitt input level (initial value in single-chip mode is Automotive level)

ROM security function

Capable of protecting the content of ROM (MASK ROM product only)

\*: Controller Area Network (CAN) - License of Robert Bosch GmbH

# **■** Product overview

Table 1.1-1 Product Overview (1/2)

| Features                                  | MB90362                        | MB90362T | MB90362S     | MB90362TS                           | MB90V340<br>A-101 | MB90V340<br>A-102 |  |
|-------------------------------------------|--------------------------------|----------|--------------|-------------------------------------|-------------------|-------------------|--|
| CPU                                       | F <sup>2</sup> MC-16LX CPU     |          |              |                                     |                   |                   |  |
| System clock pin                          |                                |          |              | 6, 1/2 when PLI<br>as (4 MHz osc. F |                   |                   |  |
| Sub clock pin (X0A, X1A) Yes No           |                                |          | No           | Yes                                 |                   |                   |  |
| Clock supervisor                          | No                             |          |              |                                     |                   |                   |  |
| ROM                                       | ROM MASK ROM, 64               |          | M, 64K bytes | , 64K bytes                         |                   | External          |  |
| RAM capacitance                           | 3K byt                         |          | oytes        |                                     | 30K bytes         |                   |  |
| CAN interface                             |                                | 1 ch     | nannel       |                                     | 3 channels        |                   |  |
| Low voltage/CPU operation detection reset | No                             | Yes      | No           | Yes                                 | N                 | lo                |  |
| Package                                   | LQFP-48                        |          |              | PGA-299                             |                   |                   |  |
| Power supply for emulator*                | -                              |          |              | Y                                   | es                |                   |  |
| Corresponding EVA product name            | me MB90V340A-102 MB90V340A-101 |          |              |                                     |                   |                   |  |

<sup>\*:</sup> It is setting of Jumper switch (TOOL  $V_{CC}$ ) when Emulator (MB2147-01) is used. Please refer to Emulator hardware manual.

| Features                                  | MB90F362                                                                                                                    | MB90F362T | MB90F362S | MB90F362TS |  |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|-----------|-----------|------------|--|
| CPU                                       | F <sup>2</sup> MC-16LX CPU                                                                                                  |           |           |            |  |
| System clock pin                          | PLL clock multiplier (X1, X2, X3, X4, X6, 1/2 when PLL stops) Minimum instruction execution time: 42 ns (4 MHz osc. PLL X6) |           |           |            |  |
| Sub clock pin (X0A, X1A)                  | Y                                                                                                                           | es        | 1         | No         |  |
| Clock supervisor                          | No                                                                                                                          |           |           |            |  |
| ROM                                       | Flash memory, 64K bytes                                                                                                     |           |           |            |  |
| RAM capacitance                           |                                                                                                                             | 3K        | bytes     |            |  |
| CAN interface                             |                                                                                                                             | 1 ch      | nannel    |            |  |
| Low voltage/CPU operation detection reset | No                                                                                                                          | Yes       | No        | Yes        |  |
| Package                                   | LQFP-48                                                                                                                     |           |           |            |  |
| Corresponding EVA product name            | MB90V340A-102 MB90V340A-101                                                                                                 |           |           | 340A-101   |  |

Table 1.1-2 Product Overview (2/2)

| Features                                  | MB90367                                       | MB90367T                                                                                                                    | MB90367S            | MB90367TS | MB90V340<br>A-103 | MB90V340<br>A-104 |
|-------------------------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------|-----------|-------------------|-------------------|
| CPU                                       |                                               |                                                                                                                             | F <sup>2</sup> MC-1 | 6LX CPU   |                   |                   |
| System clock pin                          |                                               | PLL clock multiplier (X1, X2, X3, X4, X6, 1/2 when PLL stops) Minimum instruction execution time: 42 ns (4 MHz osc. PLL X6) |                     |           |                   |                   |
| Sub clock pin (X0A, X1A)                  | Yes No (Internal CR oscillation car subclock) |                                                                                                                             | an be used as       | Yes       |                   |                   |
| Clock supervisor                          | Yes                                           |                                                                                                                             |                     |           |                   |                   |
| ROM                                       | MASK ROM, 64K bytes                           |                                                                                                                             |                     | Exte      | ernal             |                   |
| RAM capacitance                           | 3K bytes 30K byte                             |                                                                                                                             |                     | bytes     |                   |                   |
| CAN interface                             | 1 channel 3 ch                                |                                                                                                                             |                     | 3 cha     | nnels             |                   |
| Low voltage/CPU operation detection reset | No Yes No Yes                                 |                                                                                                                             |                     | No        |                   |                   |
| Package                                   | LQFP-48                                       |                                                                                                                             |                     | PGA-299   |                   |                   |
| Power supply for emulator*                | - Yes                                         |                                                                                                                             |                     | es        |                   |                   |
| Corresponding EVA product name            | MB90V340A-104 MB90V340A-103                   |                                                                                                                             |                     |           |                   |                   |

<sup>\*:</sup> It is setting of Jumper switch (TOOL V<sub>CC</sub>) when Emulator (MB2147-01) is used. Please refer to Emulator hardware manual.

| Features                                  | MB90F367                                                                                                                    | MB90F367T           | MB90F367S | MB90F367TS |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|---------------------|-----------|------------|
| CPU                                       |                                                                                                                             | F <sup>2</sup> MC-1 | 6LX CPU   |            |
| System clock pin                          | PLL clock multiplier (X1, X2, X3, X4, X6, 1/2 when PLL stops) Minimum instruction execution time: 42 ns (4 MHz osc. PLL X6) |                     |           |            |
| Sub clock pin (X0A, X1A)                  | Yes No (Internal CR oscillation can be used as subclock)                                                                    |                     |           |            |
| Clock supervisor                          | Yes                                                                                                                         |                     |           |            |
| ROM                                       | Flash memory, 64K bytes                                                                                                     |                     |           |            |
| RAM capacitance                           | 3K bytes                                                                                                                    |                     |           |            |
| CAN interface                             | 1 channel                                                                                                                   |                     |           |            |
| Low voltage/CPU operation detection reset | No Yes No Yes                                                                                                               |                     | Yes       |            |
| Package                                   | LQFP-48                                                                                                                     |                     |           |            |
| Corresponding EVA product name            | MB90V340A-104 MB90V340A-103                                                                                                 |                     | 340A-103  |            |

# **■** Features

Table 1.1-3 MB90360 Features (1/2)

| Features             | MB90F362/T(S), MB90362/T(S)<br>MB90F367/T(S), MB90367/T(S)                                                                                                                                                                                                                                                                                 | MB90V340A-101, MB90V340A-102<br>MB90V340A-103, MB90V340A-104                                                                                                             |  |
|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| UART                 | 2 channels                                                                                                                                                                                                                                                                                                                                 | 5 channels                                                                                                                                                               |  |
|                      | Wide range of baud rate settings using a dedicated reload timer LIN functionality working either as LIN master or LIN slave device                                                                                                                                                                                                         |                                                                                                                                                                          |  |
| A/D converter        | 16 channels                                                                                                                                                                                                                                                                                                                                | 24 channels                                                                                                                                                              |  |
|                      | 10-bit or 8-bit resolution<br>Conversion time: Minimum 3 μs include sample                                                                                                                                                                                                                                                                 | time (per one channel)                                                                                                                                                   |  |
| 1612 1 13            | 2 channels                                                                                                                                                                                                                                                                                                                                 | 4 channels                                                                                                                                                               |  |
| 16-bit reload timer  | Operation clock frequency: fsys/2 <sup>1</sup> , fsys/2 <sup>3</sup> , fsys/Support External Event Count function                                                                                                                                                                                                                          | /2 <sup>5</sup> (fsys=System clock freq.)                                                                                                                                |  |
| 1611170              | 1 channel                                                                                                                                                                                                                                                                                                                                  | 4 channels                                                                                                                                                               |  |
| 16-bit I/O timer     | I/O timer 0 (clock input FRCK0) corresponding ICU 0/1/2/3.                                                                                                                                                                                                                                                                                 | I/O timer 0 (clock input FRCK0) corresponds to ICU 0/1/2/3, OCU 0/1/2/3 I/O timer 1 (clock input FRCK1) corresponds to ICU 4/5/6/7, OCU 4/5/6/7                          |  |
|                      | Signal an interrupt when overflowing Supports Timer Clear when a match with Output Compare (Channel 0, 4) Operation clock freq.: fsys/2 <sup>1</sup> , fsys/2 <sup>2</sup> , fsys/2 <sup>3</sup> , fsys/2 <sup>4</sup> , fsys/2 <sup>5</sup> , fsys/2 <sup>6</sup> , fsys/2 <sup>7</sup> (fsys=System clock freq.)                         |                                                                                                                                                                          |  |
|                      | 4 channels                                                                                                                                                                                                                                                                                                                                 | 8 channels                                                                                                                                                               |  |
| 16-bit input capture | Maintains I/O timer value by pin input (rising ed interrupt.                                                                                                                                                                                                                                                                               | ge, falling edge, or both edges) and generates                                                                                                                           |  |
|                      | 2 channels                                                                                                                                                                                                                                                                                                                                 | 8 channels                                                                                                                                                               |  |
| 8-/16-bit PPG        | Supports 8-bit and 16-bit operation modes Four 8-bit reload counter Four 8-bit reload registers for L pulse width Four 8-bit reload registers for H pulse width                                                                                                                                                                            | Supports 8-bit and 16-bit operation modes Sixteen 8-bit reload counter Sixteen 8-bit reload registers for L pulse width Sixteen 8-bit reload registers for H pulse width |  |
|                      | A pair of 8-bit reload counters can be configured as one 16-bit reload counter or as 8-bit prescaler plus 8-bit reload counter  Operation clock freq.: fsys, fsys/2 <sup>1</sup> , fsys/2 <sup>2</sup> , fsys/2 <sup>3</sup> , fsys/2 <sup>4</sup> or 102.4 µs fosc=@5MHz  (fsys=system clock frequency, fosc=oscillation clock frequency) |                                                                                                                                                                          |  |

Table 1.1-3 MB90360 Features (2/2)

| Features                                  | MB90F362/T(S), MB90362/T(S)<br>MB90F367/T(S), MB90367/T(S)                                                                                                                                                                                                                                                                                                              | MB90V340A-101, MB90V340A-102<br>MB90V340A-103, MB90V340A-104                                                                                                                                                                                                            |  |  |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| CAN interface                             | 1 channel                                                                                                                                                                                                                                                                                                                                                               | 3 channels                                                                                                                                                                                                                                                              |  |  |
|                                           | Conforms to CAN Specification Version 2.0 Part A and B Automatic re-transmission in case of error Automatic transmission responding to Remote Frame 16 message buffers for transmission/reception Supports multiple messages Flexible configuration of acceptance filtering: • Full bit compare/Full bit mask/2 partial bit masks • Supports up to 1 Mbps communication |                                                                                                                                                                                                                                                                         |  |  |
| External interrupt (8 channels)           | Can be programmed edge                                                                                                                                                                                                                                                                                                                                                  | sensitive or level sensitive                                                                                                                                                                                                                                            |  |  |
| D/A converter                             | -                                                                                                                                                                                                                                                                                                                                                                       | 2 channels                                                                                                                                                                                                                                                              |  |  |
| Low voltage/CPU operation detection reset | Corresponds to product with T-suffix only                                                                                                                                                                                                                                                                                                                               | -                                                                                                                                                                                                                                                                       |  |  |
| Clock supervisor                          | MB90F367/T(S), MB90367/T(S) only                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                         |  |  |
| Subclock<br>(Maximum 100 kHz)             | Corresponds to product without T-suffix only<br>Corresponds to MB90V340A-102/MB90V340A-104 only                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                         |  |  |
| I/O port                                  | Supports general-purpose I/O (CMOS output): - 34 ports (product without S-suffix) - 36 ports (product with S-suffix) Input level setting: - Port2, Port4, Port6, Port8: selectable from CMOS/Automotive level                                                                                                                                                           | Supports general-purpose I/O (CMOS output):  - 80 ports (product without S-suffix)  - 82 ports (product with S-suffix)  Input level setting  - Port 0 to Port 3: selectable from CMOS/ Automotive/TTL level  - Port 4 to Port A: selectable from CMOS/ Automotive level |  |  |
| Flash memory                              | Supports automatic programming, Embedded Algorithm <sup>TM*</sup> , Write/Erase/Erase-Suspend/Resume commands A flag indicating completion of the algorithm Number of erase cycles: 10,000 times Data retention time: 20 years Flash Security Feature for protecting the content of the Flash                                                                           |                                                                                                                                                                                                                                                                         |  |  |
| ROM security                              | Protects the content of ROM (MASK ROM product only)                                                                                                                                                                                                                                                                                                                     | -                                                                                                                                                                                                                                                                       |  |  |

<sup>\*:</sup>Embedded Algorithm is a registered trademark of Advanced Micro Device Inc.

# 1.2 Block Diagram of MB90360 series

Figure 1.2-3 shows a block diagram of the MB90360.

# ■ Block Diagram of Evaluation Chip





Figure 1.2-2 Block Diagram of Evaluation Chip (MB90V340A-103/104)

# ■ Block Diagram of Flash/Mask ROM Version



Figure 1.2-3 Block Diagram of Flash/Mask ROM Version

# 1.3 Package Dimensions

MB90360 series has a package.

Note that the dimensions show below are reference dimensions. For formal dimensions of each package, contact us.

# ■ Package Dimensions

Figure 1.3-1 shows the package dimensions of LQFP-48 type.

48-pin plastic LQFP Lead pitch 0.50 mm Package width ×  $7 \times 7 \text{ mm}$ package length Lead shape Gullwing Sealing method Plastic mold Mounting height 1.70 mm MAX Weight 0.17 g Code (FPT-48P-M26) P-LFQFP48-7×7-0.50 (Reference)

Figure 1.3-1 Package Dimensions of LQFP-48 Type



# 1.4 Pin Assignment

This section shows the pin assignments for the MB90360 series.

# **■** Pin assignment (LQFP-48)

Figure 1.4-1 shows the pin assignments of LQFP-48 type.



# 1.5 Pin Functions

# Table 1.5-1 describes the pin functions of the MB90360 series.

# **■** Pin Functions

Table 1.5-1 Pin Description (1/3)

| Pin number | Pin name               | Circuit type | Functional description                                                                                     |
|------------|------------------------|--------------|------------------------------------------------------------------------------------------------------------|
| 1          | AV <sub>CC</sub>       | I            | V <sub>CC</sub> power input pin for analog circuit                                                         |
| 2          | AVR                    | -            | Power (Vref+) input pin for A/D converter. The power supply should not be input V <sub>CC</sub> exceeding. |
| 3 to 8     | P60 to P65             | Н            | General-purpose I/O port                                                                                   |
|            | AN0 to AN5             | 1            | Analog input pin for A/D converter.                                                                        |
| 9 to 10    | P66, P67               | Н            | General-purpose I/O port                                                                                   |
|            | AN6, AN7               | 1            | Analog input pin for A/D converter                                                                         |
|            | PPGC(D),<br>PPGE(F)    |              | Output pin for PPG                                                                                         |
| 11         | P80                    | F            | General-purpose I/O port                                                                                   |
|            | ADTG                   | 7            | Trigger input pin for A/D converter                                                                        |
|            | INT12R                 | 7            | External interrupt request input pin for INT12R.                                                           |
| 12 to 14   | P50 to P52             | Н            | General-purpose I/O port (I/O circuit type of P50 is different from that of MB90V340A)                     |
|            | AN8 to AN10            | 1            | Analog input pin for A/D converter                                                                         |
| 15         | P53                    | Н            | General-purpose I/O port                                                                                   |
|            | AN11                   |              | Analog input pin for A/D converter                                                                         |
|            | TIN3                   |              | Event input pin for reload timer 3                                                                         |
| 16         | P54                    | Н            | General-purpose I/O port                                                                                   |
|            | AN12                   |              | Analog input pin for A/D converter                                                                         |
|            | TOT3                   |              | Output pin for reload timer 3                                                                              |
|            | INT8                   |              | External interrupt request input pin for INT8                                                              |
| 17 to 19   | P55 to P57             | Н            | General-purpose I/O port                                                                                   |
|            | AN13 to AN15           |              | Analog input pin for A/D converter                                                                         |
|            | INT10, INT11,<br>INT13 |              | External interrupt request input pin for INT10, INT11 and INT13                                            |
| 20         | MD2                    | D            | Input pin for selecting operation mode                                                                     |
| 21, 22     | MD1,MD0                | С            | Input pin for selecting operation mode                                                                     |
| 23         | RST                    | Е            | Reset input                                                                                                |
| 24         | V <sub>CC</sub>        | -            | Power input pin (3.5 V to 5.5 V)                                                                           |
| 25         | $V_{SS}$               | -            | Power input pin (0 V)                                                                                      |
|            | 1                      | 1            | 1                                                                                                          |

Table 1.5-1 Pin Description (2/3)

| Pin number | Pin name            | Circuit type | Functional description                                                                                                                                              |
|------------|---------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 26         | С                   | I            | Capacity pin for stabilizing power supply.  It should be connected to higher than or equal to 0.1 µF ceramic capacitor.                                             |
| 27         | X0                  | A            | Oscillation input pin                                                                                                                                               |
| 28         | X1                  | A            | Oscillation output pin                                                                                                                                              |
| 29 to 32   | P24 to P27          | G            | General-purpose I/O port The register can be set to select whether to use pull-up register. This function is enabled in single-chip mode.                           |
|            | IN0 to IN3          |              | Event input pin for input capture 0 to 3.                                                                                                                           |
| 33, 34     | P22 to P23          | J            | General-purpose I/O port The pull-up resistor ON/OFF can be set by setting the register. This function becomes valid at shingle-chip mode. High current output port |
|            | PPGF(E),<br>PPGD(C) |              | Output pin for PPG                                                                                                                                                  |
| 35, 36     | P20, P21            | J            | General-purpose I/O port The pull-up resistor ON/OFF can be set by setting the register. This function becomes valid at shingle-chip mode. High current output port |
| 37         | P85                 | K            | General-purpose I/O port                                                                                                                                            |
|            | SIN1                |              | Serial data input pin for UART1                                                                                                                                     |
| 38         | P87                 | F            | General-purpose I/O port                                                                                                                                            |
|            | SCK1                |              | Clock I/O pin for UART1                                                                                                                                             |
| 39         | P86                 | F            | General-purpose I/O port                                                                                                                                            |
|            | SOT1                |              | Serial data output pin for UART1                                                                                                                                    |
| 40         | P43                 | F            | General-purpose I/O port                                                                                                                                            |
|            | TX1                 |              | TX output pin for CAN1 interface                                                                                                                                    |
| 41         | P42                 | F            | General-purpose I/O port                                                                                                                                            |
|            | RX1                 |              | RX input pin for CAN1 interface                                                                                                                                     |
|            | INT9R               |              | External interrupt request input pin for INT9R (sub)                                                                                                                |
| 42         | P83                 | F            | General-purpose I/O port                                                                                                                                            |
|            | SOT0                |              | Serial data output pin for UART0                                                                                                                                    |
|            | ТОТ2                |              | Output pin for reload timer 2                                                                                                                                       |
| 43         | P84                 | F            | General-purpose I/O port                                                                                                                                            |
|            | SCK0                |              | Clock I/O pin for UART0                                                                                                                                             |
|            | INT15R              |              | External interrupt request input pin for INT15R                                                                                                                     |
| 44         | P82                 | K            | General-purpose I/O port                                                                                                                                            |
|            | SIN0                |              | Serial data input pin for UART0                                                                                                                                     |
|            | INT14R              |              | External interrupt request input pin for INT14R                                                                                                                     |
|            | TIN2                |              | Event input pin for reload timer 2                                                                                                                                  |

# **CHAPTER 1 OVERVIEW**

Table 1.5-1 Pin Description (3/3)

| Pin number | Pin name         | Circuit type | Functional description                                                                   |
|------------|------------------|--------------|------------------------------------------------------------------------------------------|
| 45         | P44              | F            | General-purpose I/O port (I/O circuit type of P44 is different from that of MB90V340A.)  |
|            | FRCK0            |              | Free-run timer 0 clock pin                                                               |
| 46, 47     | P40, P41         | F            | General-purpose I/O port<br>(product with S-suffix and MB90V340A-101/103 only)           |
|            | X1A, X0A         | В            | Oscillation input pin for subclock (product without S-suffix and MB90V340A-102/104 only) |
| 48         | AV <sub>SS</sub> | I            | V <sub>SS</sub> power input pin for analog circuit                                       |

# 1.6 Input-Output Circuits

# Table 1.6-1 lists the input-output circuits.

# ■ Input-output Circuits

Table 1.6-1 I/O Circuit Types (1/4)

| Туре | Circuit                                | Remarks                                                                                                                       |
|------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|
| A    | X1 Xout X0 Standby control signal      | Oscillation circuit High-speed oscillation feedback resistor = approx. 1 $M\Omega$                                            |
| В    | X1A Xout X0A Standby control signal    | Oscillation circuit Low-speed oscillation feedback resistor = approx. $10~\text{M}\Omega$                                     |
| С    | R Hysteresis input                     | Mask ROM device: CMOS hysteresis input pin Flash device: CMOS input                                                           |
| D    | R Hysteresis input  Pull-down resistor | Mask ROM device: CMOS hysteresis input pin Pull-down resistor value: approx. 50 kΩ  Flash device: CMOS input pin No Pull-down |

Table 1.6-1 I/O Circuit Types (2/4)

| Туре | Circuit                                                                                             | Remarks                                                                                                                                                                                                                                            |
|------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Е    | Pull-up resistor  Hysteresis input                                                                  | CMOS hysteresis input pin Pull-up resister value: approx. $50 \text{ k}\Omega$                                                                                                                                                                     |
| F    | Nout  Nout  Hysteresis input  Automotive input  Standby control for input shutdown                  | CMOS level output ( $I_{OL} = 4 \text{ mA}$ , $I_{OH} = -4 \text{ mA}$ ) CMOS hysteresis inputs (with the standby-time input shutdown function) Automotive input (with the standby-time input shutdown function)                                   |
| G    | Pull-up control  Pout  Nout  Hysteresis input  Automotive input  Standby control for input shutdown | CMOS level output ( $I_{OL}$ = 4 mA, $I_{OH}$ =-4 mA) CMOS hysteresis inputs (with the standby-time input shutdown function) Automotive input (with the standby-time input shutdown function) Programmable pull-up resistor: approx. 50 k $\Omega$ |

Table 1.6-1 I/O Circuit Types (3/4)

| Туре | Circuit                                                                                                                | Remarks                                                                                                                                                                                                                                         |
|------|------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Н    | Nout  Nout  Hysteresis input  Automotive input  Standby control for input shutdown  Analog input                       | CMOS level output (I <sub>OL</sub> = 4 mA, I <sub>OH</sub> =-4 mA) CMOS hysteresis inputs (with the standby-time input shutdown function) Automotive input (with the standby-time input shutdown function) A/D analog input                     |
| I    |                                                                                                                        | Power supply input protection circuit                                                                                                                                                                                                           |
| 1    | Pull-up control  Pout High current output  Nout Hysteresis input  Automotive input  Standby control for input shutdown | CMOS level output ( $I_{OL}=20~mA,I_{OH}=-14~mA$ ) CMOS hysteresis inputs (with the standby-time input shutdown function) Automotive inputs (with the standby-time input shutdown function) Programmable pull-up resistor: approx. $50~k\Omega$ |

Table 1.6-1 I/O Circuit Types (4/4)

| Туре | Circuit                                                                         | Remarks                                                                                                                                                                                                                      |
|------|---------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| K    | Pout  Nout  R  CMOS input  Automotive input  Standby control for input shutdown | CMOS level output ( $I_{OL} = 4 \text{ mA}$ , $I_{OH} = -4 \text{ mA}$ ) CMOS hysteresis inputs (with the standby-time input shutdown function) Automotive hysteresis inputs (with the standby-time input shutdown function) |

# 1.7 Handling Device

This section explains notes on handling the MB90360 series.

# **■** Handling the Device

# Preventing latch-up

### CMOS IC chips may suffer latch-up under the following conditions:

- A voltage higher than  $V_{CC}$  or lower than  $V_{SS}$  is applied to an input or output pin.
- A voltage higher than the rated voltage is applied between  $V_{CC}$  and  $V_{SS}$ .
- The AV<sub>CC</sub> power supply is applied before the V<sub>CC</sub> voltage.

Latch-up may increase the power supply current drastically, causing thermal damage to the device.

When used, note that maximum rated voltage is not exceeded.

For the same reason, also be careful not to let the analog power-supply voltage  $(AV_{CC,}AVR)$  exceed the digital power-supply voltage.

# Treatment of unused pins

Leaving unused input pins open may result in misbehavior or latch up and possible permanent damage of the device. Therefore, they must be pulled up or pulled down through resistors. In this case those resistors should be more than  $2 \ k\Omega$ .

Unused bidirectional pins should be set to the output state and can be left open, or the input state with the above described connection.

### Using external clock

To use external clock, drive the X0 (X0A) pin and leave X1 (X1A) pin open.

Figure 1.7-1 Using External Clock



## Precautions for when not using a sub clock signal

If you do not connect pins X0A and X1A to an oscillator, use pull-down handling on the X0A pin, and leave the X1A pin open.

### Notes on during operation of PLL clock mode

If the PLL clock mode is selected, the microcontroller attempts to be working with the free-running frequency of self-oscillating circuit in the PLL even when there is no external oscillator or external clock input is stopped. Performance of this operation, however, cannot be guaranteed.

# Power supply pins (V<sub>CC</sub>/V<sub>SS</sub>)

- If there are multiple V<sub>CC</sub> and V<sub>SS</sub> pins, from the point of view of device design, pins to be of the same
  potential are connected the inside of the device to prevent such malfunctioning as latch up.
  - To reduce unnecessary radiation, prevent malfunctioning of the strobe signal due to the rise of ground level, and to keep the recommended DC characteristics specified as the total output current, be sure to connect the  $V_{CC}$  and  $V_{SS}$  pins to the power supply and ground externally (see Figure 1.7-2).
- Connect V<sub>CC</sub> and V<sub>SS</sub> to the device from the power supply source with lowest possible impedance.
- It is recommended to connect a capacitor of about 0.1 μF as a bypass capacitor between V<sub>CC</sub> and V<sub>SS</sub> in the vicinity of V<sub>CC</sub> and V<sub>SS</sub> pins of the device



Figure 1.7-2 Power Supply Pins (V<sub>CC</sub>/V<sub>SS</sub>)

### Pull-up/down resistors

The MB90360 Series does not support internal pull-up/down resistors (except Port2: programmable pull-up resistors). Use pull-up/down handling where needed.

### Crystal Oscillator Circuit

Noises around X0 or X1 pins may be possible causes of abnormal operations. Make sure to provide bypass capacitors via shortest distance from X0, X1 pins, crystal oscillator (or ceramic resonator) and ground lines, and make sure, to the utmost effort, that lines of oscillation circuit not cross the lines of other circuits.

It is highly recommended to provide a printed circuit board art work surrounding X0 and X1 pins with a ground area for stabilizing the operation.

# Turning-on Sequence of Power Supply to A/D Converter and Analog Inputs

Make sure to turn on the A/D converter power supply (AV<sub>CC</sub>, AVR) and analog inputs (AN0 to AN15) after turning-on the digital power supply ( $V_{CC}$ ).

Turn-off the digital power supply after turning off the A/D converter power supply and analog inputs. In this case, make sure that the voltage not exceed AVR or  $AV_{CC}$ .

#### Connection of Unused Pins of A/D Converter

Connect unused pins of A/D converter as  $AV_{CC} = V_{CC}$ ,  $AV_{SS} = AVR = V_{SS}$ .

### Notes on Energization

To prevent malfunction of the internal voltage regulator, supply voltage profile while turning on the power supply should be slower than 50  $\mu$ s from 0.2 V to 2.7 V.

### Stabilization of power supply voltage

If the power supply voltage varies acutely even within the operation assurance range of the  $V_{CC}$  power supply voltage, a malfunction may occur. The  $V_{CC}$  power supply voltage must therefore be stabilized. As stabilization guidelines, stabilize the power supply voltage so that  $V_{CC}$  ripple fluctuations (peak to peak value) in the commercial frequencies (50 to 60 Hz) fall within 10% of the standard  $V_{CC}$  power supply voltage and the transient fluctuation rate becomes 0.1 V/ms or less in instantaneous fluctuation for power supply switching.

### Note on using CAN Function

The MB90360 series does not contain the clock modulation function. So, at using CAN, the DIRECT bit of the CAN direct mode register (CDMR) must be set "1". (See Table 1.7-1). If the DIRECT bit is not set correctly, the device does not operate normally.

Table 1.7-1 Setting of Clock Modulation and CAN Direct Mode

|                  | Clock modulation setting (CMCR:PMOD bit)    | CAN direct mode setting (setting of CDMR:DIRECT bit) |
|------------------|---------------------------------------------|------------------------------------------------------|
| Required setting | 0: Disable clock modulation (initial value) | 1: Enable CAN direct mode                            |
| Setting disabled | 1: Enable clock modulation                  | 0: Disable CAN direct mode (initial value)           |

### Note:

For details on the clock modulation, see "CHAPTER 6 CLOCK SUPERVISOR".

For details on the CAN direct mode, see "21.11 Setting Configuration of Multi-level Message Buffer".

### Flash security Function

The security bit is located in the area of the flash memory.

If protection code 01<sub>H</sub> is written in the security bit, the flash memory is in the protected state by security.

Therefore please do not write 01<sub>H</sub> in this address if you do not use the security function.

Please refer to following table for the address of the security bit.

|                                 | Flash memory size             | Address of security bit |
|---------------------------------|-------------------------------|-------------------------|
| MB90F362/T(S),<br>MB90F367/T(S) | Embedded 512Kbit flash memory | FF0001 <sub>H</sub>     |

### ● For the diversion of MB90340-series software assets

In programming of the MB90360 series, keep the following points in mind for the diversion of MB90340-series software assets in particular.

Access to the registers which do not exist in the MB90360 series.

As for the registers and bits which exist in MB90340 series but not in the MB90360 series, do not access them or ensure that the initial value is set. Setting any other value than the initial value may cause an abnormal operation in emulation using MB90V340.

Setting of the external interrupt factor select register (EISSR).

The MB90360 series is not equipped with the external interrupt request input, INT8R, INT9, INT10, INT11, INT12, INT13, INT14 and INT15.

Enabling unequipped terminals causes a false operation. First set the EISSR and then set each of the registers when DTP/external interrupt is used.

# **CHAPTER 2**

# **CPU**

# This chapter explains the CPU.

- 2.1 Outline of the CPU
- 2.2 Memory Space
- 2.3 Memory Map
- 2.4 Linear Addressing
- 2.5 Bank Addressing Types
- 2.6 Multi-byte Data in Memory Space
- 2.7 Registers
- 2.8 Register Bank
- 2.9 Prefix Codes
- 2.10 Interrupt Disable Instructions
- 2.11 Precautions for Use of "DIV A, Ri" and "DIVW A, RWi" Instructions

# 2.1 Outline of the CPU

The F<sup>2</sup>MC-16LX CPU core is a 16-bit CPU designed for applications that require high-speed real-time processing, such as home-use or vehicle-mounted electronic appliances. The F<sup>2</sup>MC-16LX instruction set is designed for controller applications, and is capable of high-speed, highly efficient control processing.

### ■ Outline of the CPU

In addition to 16-bit data, the  $F^2MC-16LX$  CPU core can process 32-bit data by using an internal 32-bit accumulator. (32-bit data can be processed with some instructions.) Up to 16M bytes of memory space (expandable) can be used, which can be accessed by either the linear pointer or bank method. The instruction system, based on the  $F^2MC-8$  A-T architecture, has been reinforced by adding instructions compatible with high-level languages, expanding addressing modes, reinforcing multiplication and division instructions, and enhancing bit processing. The features of the  $F^2MC-16LX$  CPU are explained below.

- Minimum instruction execution time: 42 ns (at 4-MHz oscillation, 6 times clock multiplication)
- Maximum memory space: 16M bytes, accessed in linear or bank mode
- Instruction set optimized for controller applications
  - Rich data types: Bit, byte, word, long word
  - Extended addressing modes: 23 types
  - High-precision operation (32-bit length) based on 32-bit accumulator
- Powerful interrupt functions

Eight priority levels (programmable)

CPU-independent automatic transfer

Up to 16 channels of the extended intelligent I/O service

- Instruction set compatible with high-level language (C)/multitasking
  - System stack pointer/instruction set symmetry/barrel-shift instructions
- Improved execution speed: 4 bytes queue

# 2.2 Memory Space

An F<sup>2</sup>MC-16LX CPU has a 16M bytes memory space. All data program input and output managed by the F<sup>2</sup>MC-16LX CPU are located in this 16M bytes memory space. The CPU accesses the resources by indicating their addresses using a 24-bit address bus.

# **■** Outline of CPU Memory Space

Figure 2.2-1 shows a sample relationship between the F<sup>2</sup>MC-16LX system and memory map.



### ■ ROM area

Vector table area (address: FFFC00<sub>H</sub> to FFFFFF<sub>H</sub>)

This area is used as a vector table for reset/interrupt and CALLV vector.

This area is allocated at the highest addresses of the ROM area. The start address of the corresponding processing routine is set as data in each vector table address.

Program area (address: FF0000<sub>H</sub> to FFFBFF<sub>H</sub>)

ROM is built in as an internal program area.

The size of internal ROM differs for each model.

### ■ RAM Area

Data area (address: From 000100<sub>H</sub> to 000CFF<sub>H</sub> (for 3K bytes))

The static RAM is built in as an internal data area.

The size of internal RAM differs for each model.

General-purpose register area (address: 000180<sub>H</sub> to 00037F<sub>H</sub>)

Auxiliary registers used for 8-bit, 16-bit, and 32-bit arithmetic operations and transfer are allocated in this area.

Since this area is allocated to a part of the RAM area, it can be used as ordinary RAM.

When this area is used as a general-purpose register, general-purpose register addressing enables highspeed access with short instructions.

Extended intelligent I/O service (EI<sup>2</sup>OS) descriptor area (address: 000100<sub>H</sub> to 00017F<sub>H</sub>)

This area retains the transfer modes, I/O addresses, transfer count, and buffer addresses.

Since this area is allocated to a part of the RAM area, it can be used as ordinary RAM.

### ■ I/O Area

● Interrupt control register area (address: 0000B0<sub>H</sub> to 0000BF<sub>H</sub>)

The interrupt control registers (ICR00 to ICR15) correspond to all peripheral functions that have an interrupt function. These registers set interrupt levels and control the extended intelligent I/O service (EI<sup>2</sup>OS).

Peripheral function control register area (address: 000020<sub>H</sub> to 0000AF<sub>H</sub>, 0000C0<sub>H</sub> to 0000EF<sub>H</sub>, 007900<sub>H</sub> to 007FFF<sub>H</sub>)

This register controls the built-in peripheral functions and inputs and outputs data.

I/O port control register area (address: 000000<sub>H</sub> to 00001F<sub>H</sub>)

This register controls I/O ports, and inputs and outputs data.

# ■ Address generation types

The F<sup>2</sup>MC-16LX has the following 2 addressing modes:

# Linear addressing

An entire 24-bit address is specified by an instruction.

# Bank addressing.

The eight high-order bits of an address are specified by an appropriate bank register, and the remaining 16 low-order bits are specified by an instruction.

# 2.3 Memory Map

# The memory map of the MB90360 Series is shown in Figure 2.3-1.

# ■ Memory Map

The ROM data in the high-order portion of FF-bank can be seen as an image in the higher 00-bank in order to support the small model C compiler. Since the low-order 16 bits are identical, this part of the ROM data can be referred without using the far specification in the pointer declaration.

For example, when  $00C000_H$  is accessed, the contents of ROM at  $FFC000_H$  are read. However, since the ROM area in the FF bank exceeds 32K bytes, its entire image cannot be mirrored in the 00 bank.

The image between  $FF8000_H$  and  $FFFFF_H$  is visible in bank 00, whereas the data between  $FF0000_H$  and  $FF7FFF_H$  is only visible in bank FF.



Figure 2.3-1 Memory Map

#### 2.4 **Linear Addressing**

# There are 2 types of linear addressing:

- 24-bit operand specification: Directly specifies a 24-bit address using operands.
- 32-bit register indirect specification: Indirectly specifies the 24 low-order bits of a 32bit general-purpose register value as the address.

# ■ 24-bit Operand Specification

Figure 2.4-1 shows an example of 24-bit operand specification. Figure 2.4-2 shows an example of 32-bit register indirect specification.

JMPP 123456H > 17452Dн Old program counter 452D 17 JMPP 123456H + Program bank Next instruction > 123456н New program counter 12 3456 + Program bank

Figure 2.4-1 Example of Linear Method (24-bit operand specification)

Figure 2.4-2 Example of Linear Method (32-bit register indirect specification)



# 2.5 Bank Addressing Types

In the bank method, the 16M bytes space is divided into 256 for 64K bytes banks. The following 5 bank registers are used to specify the banks corresponding to each space:

- Program bank register (PCB)
- Data bank register (DTB)
- User stack bank register (USB)
- System stack bank register (SSB)
- Additional bank register (ADB)

# ■ Bank Addressing Types

### Program bank register (PCB)

The 64K bytes bank specified by the PCB is called a program (PC) space. The PC space contains instruction codes, vector tables, and immediate value data, for example.

### Data bank register (DTB)

The 64K bytes bank specified by the DTB is called a data (DT) space. The DT space contains readable/writable data, and control/data registers for internal and external resources.

### User stack bank register (USB)/system stack bank register (SSB)

The 64K bytes bank specified by the USB or SSB is called a stack (SP) space. The SP space is accessed when a stack access occurs during a push/pop instruction or interrupt register saving. The S flag in the condition code register determines the stack space to be accessed.

### Additional bank register (ADB)

The 64K bytes bank specified by the ADB is called an additional (AD) space. The AD space, for example, contains data that cannot fit into the DT space.

Table 2.5-1 lists the default spaces used in each addressing mode, which are pre-determined to improve instruction coding efficiency. To use a non-default space for an addressing mode, specify a prefix code corresponding to a bank before the instruction. This enables access to the bank space corresponding to the specified prefix code.

After reset, the DTB, USB, SSB, and ADB are initialized to  $00_{\rm H}$ . The PCB is initialized to a value specified by the reset vector. After reset, the DT, SP, and AD spaces are allocated in bank  $00_{\rm H}$  (000000 $_{\rm H}$  to 00FFFF<sub>H</sub>), and the PC space is allocated in the bank specified by the reset vector.

Table 2.5-1 Default Space

| Default space    | Addressing mode                                                      |  |
|------------------|----------------------------------------------------------------------|--|
| Program space    | PC indirect, program access, branch                                  |  |
| Data space       | Addressing mode using @RW0, @RW1, @RW4, or @RW5, @A, addr16, and dir |  |
| Stack space      | Addressing mode using PUSHW, POPW, @RW3, or @RW7                     |  |
| Additional space | Addressing mode using @RW2 or @RW6                                   |  |

Figure 2.5-1 is an example of a memory space divided into register banks.

Figure 2.5-1 Physical Addresses of Each Space FFFFFF<sub>H</sub> Program space FF0000H : PCB (Program bank register)  $\mathsf{FF}_\mathsf{H}$ B3FFFF<sub>H</sub> Additional space : ADB (Additional bank register) В30000н ВЗн Physical address 92FFFF<sub>H</sub> User stack space : USB (User stack bank register) 920000н 92н 68FFFFн Data space : DTB (Data bank register) 680000н 68н 4BFFFF<sub>H</sub> System stack space 4В0000н : SSB (System stack bank register) 4Вн 00000н

35

# 2.6 Multi-byte Data in Memory Space

Data is written to memory from the low-order addresses. Therefore, for a 32-bit data item, the low-order 16 bits are transferred before the high-order 16 bits. If a reset signal is inputted immediately after the low-order bits are written, the high-order bits might not be written.

### ■ Multi-byte Data Allocation in Memory Space

Figure 2.6-1 is a diagram of multi-byte data configuration in memory. The low-order eight bits of a data item are stored at address n, then address n+1, address n+2, address n+3, etc.



Figure 2.6-1 Sample Allocation of Multi-byte Data in Memory

# ■ Accessing Multi-byte Data

Fundamentally, accesses are made within a bank. For an instruction accessing a multi-byte data item, address  $FFFF_H$  is followed by address  $0000_H$  of the same bank. Figure 2.6-2 is an example of an instruction accessing multi-byte data.



Figure 2.6-2 Execution of MOVW A, 080FFFF<sub>H</sub>

# 2.7 Registers

The F<sup>2</sup>MC-16LX registers are largely classified into two types: special registers in the CPU and general-purpose registers in memory. The special registers are dedicated internal hardware of the CPU, and they have specific use defined by the CPU architecture. The general-purpose registers share the CPU address space with RAM. The general-purpose registers are the same as the special registers in that they can be accessed without using an address. The applications of the general-purpose registers can be specified by the user however, as is ordinary memory space.

# **■** Special Registers

The  $F^2MC-16LX$  CPU core has the following special registers:

• Accumulator (A=AH:AL) : Two 16-bit accumulators (Can be used as a single 32-bit accumulator.)

User stack pointer (USP)
 System stack pointer (SSP)
 16-bit pointer indicating the user stack area
 16-bit pointer indicating the system stack area

• Processor status (PS) : 16-bit register indicating the system status

• Program counter (PC) : 16-bit register holding the address of the program

Program bank register (PCB)
 B-bit register indicating the PC space
 Data bank register (DTB)
 8-bit register indicating the DT space

• User stack bank register (USB) : 8-bit register indicating the user stack space

• System stack bank register (SSB): 8-bit register indicating the system stack space

Additional bank register (ADB) : 8-bit register indicating the AD space
 Direct page register (DPR) : 8-bit register indicating a direct page

Figure 2.7-1 is a diagram of the special registers.

ΑН ALAccumulator USP User stack pointer SSP System stack pointer PS Processor status PC Program counter DPR Direct page register PCB Program bank register DTB Data bank register USB User bank register SSB System stack bank register ADB Additional data bank register 8 bits 16 bits 32 bits

Figure 2.7-1 Special Registers

# **■** General-purpose registers

The  $F^2MC$ -16LX general-purpose registers are located from addresses  $000180_H$  to  $00037F_H$  (maximum configuration) of main storage. The register bank pointer (RP) indicates which of the above addresses are currently being used as a register bank. Each bank has the following three types of registers. These registers are mutually dependent as described in Figure 2.7-2 .

- R0 to R7: 8-bit general-purpose register
- RW0 to RW7: 16-bit general-purpose register
- RL0 to RL3: 32-bit general-purpose register



Figure 2.7-2 General-purpose Registers

The relationship between the high-order and low-order bytes of a byte or word register is expressed as follows:

RW 
$$_{(i+4)}$$
 = R  $_{(i\times2+1)}$  × 256+R  $_{(i\times2)}$  [i=0 to 3]

The relationship between the high-order and low-order bytes of RLi and RW can be expressed as follows:

$$RL_{(i)} = RW_{(i \times 2+1)} \times 65536 + RW_{(i \times 2)} [i=0 \text{ to } 3]$$

#### **Accumulator (A)** 2.7.1

The accumulator (A) register consists of 2 16-bit arithmetic operation registers (AH and AL), and is used as a temporary storage for operation results and transfer data.

# ■ Accumulator (A)

During 32-bit data processing, AH and AL are used together. Only AL is used for word processing in 16bit data processing mode or for byte processing in 8-bit data processing mode (see Figure 2.7-3 and Figure 2.7-4). The data stored in the A register can be operated upon with the data in memory or registers (Ri, Rwi, or RLi). In the same manner as with the F<sup>2</sup>MC-8L, when a word or shorter data item is transferred to AL, the previous data item in AL is automatically sent to AH (data preservation function). The data preservation function and operation between AL and AH help improve processing efficiency.

When a byte or shorter data item is transferred to AL, the data is sign-extended or zero-extended and stored as a 16-bit data item in AL. The data in AL can be handled either as word or byte long.

When a byte-processing arithmetic operation instruction is executed on AL, the high-order eight bits of AL before operation are ignored. The high-order eight bits of the operation result all become zeroes.

The A register is not initialized by a reset. The A register holds an undefined value immediately after a reset.



Figure 2.7-3 32-bit Data Transfer

Figure 2.7-4 AL-AH Transfer **MSB** MOVW A,@RW1+6 LSB А61540н 8Fн 74н 1234н 2Вн **А6153Е**н 52н DTB А6н +6 1234н RW1 15н 38н

A before

execution

A after

execution

XXXXH

1234н

# 2.7.2 User Stack Pointer (USP) and System Stack Pointer (SSP)

USP and SSP are 16-bit registers that indicate the memory addresses for saving and restoring data when a push/pop instruction or subroutine is executed.

# ■ User Stack Pointer (USP) and System Stack Pointer (SSP)

The USP and SSP registers are used by stack instructions. The USP register is enabled when the S flag in the processor status register is "0", and the SSP register is enabled when the S flag is "1" (see

Figure 2.7-5 ). Since the S flag is set when an interrupt is accepted, register values are always saved in the memory area indicated by SSP during interrupt processing. SSP is used for stack processing in an interrupt routine, while USP is used for stack processing outside an interrupt routine. If the stack space is not divided, use only the SSP.

During stack processing, the high-order eight bits of an address are indicated by SSB (for SSP) or USB (for USP). USP and SSP are not initialized by a reset. Instead, they hold undefined values.



Figure 2.7-5 Stack Manipulation Instruction and Stack Pointer

### Note:

Specify an even-numbered address in the stack pointer whenever possible.

# 2.7.3 Processor Status (PS)

The PS register consists of the bits controlling the CPU operation and the bits indicating the CPU status.

# ■ Processor Status (PS)

As shown in Figure 2.7-6, the high-order byte of the PS register consists of a register bank pointer (RP) and an interrupt level mask register (ILM). The ILM indicates the start address of a register bank. The low-order byte of the PS register is a condition code register (CCR), containing the flags to be set or reset depending on the results of instruction execution or interrupt occurrences.

Figure 2.7-6 Processor Status (PS) Structure



# ■ Condition Code Register (CCR)

Figure 2.7-7 is a diagram of condition code register (CCR) configuration.

Figure 2.7-7 Condition Code Register (CCR) Configuration



# I: Interrupt enable flag:

Interrupt requests other than software interrupts are enabled when the I flag is 1 and are masked when the I flag is 0. The I flag is cleared by a reset.

### S: Stack flag:

When the S flag is 0, USP is enabled as the stack manipulation pointer.

When the S flag is 1, SSP is enabled as the stack manipulation pointer.

The S flag is set by an interrupt reception or a reset.

### T: Sticky bit flag:

1 is set in the T flag when there is at least one "1" in the data shifted out from the carry after execution of a logical right/arithmetic right shift instruction. Otherwise, 0 is set in the T flag. In addition, "0" is set in the T flag when the shift amount is zero.

### N: Negative flag:

The N flag is set when the MSB of the operation result is "1", and is otherwise cleared.

### Z: Zero flag:

The Z flag is set when the operation result is all zeroes, and is otherwise cleared.

### V: Overflow flag:

The V flag is set when an overflow of a signed value occurs as a result of operation execution and is otherwise cleared.

### C: Carry flag:

The C flag is set when a carry-up or carry-down from the MSB occurs as a result of operation execution, and is otherwise cleared.

# ■ Register Bank Pointer (RP)

The RP register indicates the relationship between the general-purpose registers of the  $F^2MC$ -16LX and the internal RAM addresses. Specifically, the RP register indicates the first memory address of the currently used register bank in the following conversion expression:  $[00180_H + (RP)*10_H]$  (see Figure 2.7-8). The RP register consists of five bits, and can take a value between  $00_H$  and  $1F_H$ . Register banks can be allocated at addresses from  $000180_H$  to  $00037_H$  in memory.

Even within that range, however, the register banks cannot be used as general-purpose registers if the banks are not in internal RAM. The RP register is initialized to all zeroes by a reset. An instruction may transfer an eight-bit immediate value to the RP register; however, only the low-order five bits of that data are used.

Figure 2.7-8 Register Bank Pointer (RP)



# ■ Interrupt level mask register (ILM)

The ILM register consists of three bits, indicating the CPU interrupt masking level. An interrupt request is accepted only when the level of the interrupt is higher than that indicated by these three bits. Level 0 is the highest priority interrupt, and level 7 is the lowest priority interrupt (see Table 2.7-1 ). Therefore, for an interrupt to be accepted, its level value must be smaller than the current ILM value. When an interrupt is accepted, the level value of that interrupt is set in ILM. Thus, an interrupt of the same or lower level cannot be accepted subsequently. ILM is initialized to all zeroes by a reset. An instruction may transfer an eight-bit immediate value to the ILM register, but only the low-order three bits of that data are used.

Figure 2.7-9 Interrupt Level Mask Register (ILM)



Table 2.7-1 Levels Indicated by the Interrupt Level Mask (ILM) Register

| ILM2 | ILM1 | ILM0 | Level value | Acceptable interrupt level |
|------|------|------|-------------|----------------------------|
| 0    | 0    | 0    | 0           | Interrupt disabled         |
| 0    | 0    | 1    | 1           | 0 only                     |
| 0    | 1    | 0    | 2           | Level value smaller than 1 |
| 0    | 1    | 1    | 3           | Level value smaller than 2 |
| 1    | 0    | 0    | 4           | Level value smaller than 3 |
| 1    | 0    | 1    | 5           | Level value smaller than 4 |
| 1    | 1    | 0    | 6           | Level value smaller than 5 |
| 1    | 1    | 1    | 7           | Level value smaller than 6 |

# 2.7.4 Program Counter (PC)

The PC register is a 16-bit counter that indicates the low-order 16 bits of the memory address of an instruction code to be executed by the CPU. The high-order eight bits of the address are indicated by the PCB. The PC register is updated by a conditional branch instruction, subroutine call instruction, interrupt, or reset.

The PC register can also be used as a base pointer for operand access.

# **■** Program Counter (PC)

Figure 2.7-10 shows the program counter.

Figure 2.7-10 Program Counter



# 2.8 Register Bank

A register bank consists of eight words. The register bank can be used as the following general-purpose registers for arithmetic operations: byte registers R0 to R7, word registers RW0 to RW7, and long word registers RL0 to RL3. In addition, the register bank can be used as instruction pointers.

RL0 to RL3 are used as the linear pointer that directly accesses entire space.

# ■ Register Bank

Table 2.8-1 lists the functions of the registers. Table 2.8-2 indicates the relationship between the registers.

In the same manner as for an ordinary RAM area, the register bank values are not initialized by a reset. The status before a reset is maintained. When the power is turned on, however, the register bank will have an undefined value.

Table 2.8-1 Register Functions

| R0 to R7   | Used as operands of instructions.  Note: R0 is used as a counter for barrel shift and normalization instructions. |
|------------|-------------------------------------------------------------------------------------------------------------------|
| RW0 to RW7 | Used as pointers. Used as operands of instructions. Note: RW0 is used as a counter for string instructions.       |
| RL0 to RL3 | Used as long pointers. Used as operands of instructions.                                                          |

Table 2.8-2 Relationship between Registers

|    | RW0 | RL0 |
|----|-----|-----|
|    | RW1 | KLU |
|    | RW2 | RL1 |
|    | RW3 | KL1 |
| R0 | RW4 | RL2 |
| R1 | KW4 |     |
| R2 | RW5 |     |
| R3 |     |     |
| R4 | RW6 | RL3 |
| R5 | KWO |     |
| R6 | RW7 |     |
| R7 |     |     |

Direct page register (DPR) <Initial value: 01<sub>H</sub>>

DPR specifies addr8 to addr15 of the instruction operands in direct addressing mode as shown in Figure

2.8-1 . DPR is eight bits long, and is initialized to  $01_{\rm H}$  by a reset. DPR can be read or written to by an instruction.

Figure 2.8-1 Generating a Physical Address in Direct Addressing Mode

- Program counter bank register (PCB) < Initial value: Value in reset vector>
- Data bank register (DTB) <Initial value: 00<sub>H</sub>>
- User stack bank register (USB) <Initial value: 00<sub>H</sub>>
- System stack bank register (SSB) <Initial value: 00<sub>H</sub>>
- Additional data bank register (ADB) <Initial value: 00<sub>H</sub>>

Each bank register indicates the memory bank where the PC, DT, SP (user), SP (system), or AD space is allocated. All bank registers are one byte long. PCB is initialized to  $00_{\rm H}$  by a reset. Bank registers other than PCB can be read or written to. PCB can be read but cannot be written to.

PCB is updated when the JMPP, CALLP, RETP, RETIQ, or RETF instruction branching to the entire 16M bytes space is executed or when an interrupt occurs. For operation of each register, see "2.2 Memory Space".

# 2.9 Prefix Codes

Placing a prefix code before an instruction partially changes the operation of the instruction. Three types of prefix codes can be used: bank select prefix, common register bank prefix, and flag change disable prefix.

### **■** Bank Select Prefix

The memory space used for accessing data is determined for each addressing mode.

When a bank select prefix is placed before an instruction, the memory space used for accessing data by that instruction can be selected regardless of the addressing mode.

Table 2.9-1 lists the bank select prefixes and the corresponding memory spaces.

Table 2.9-1 Bank Select Prefix

| Bank select prefix | Selected space                                                         |
|--------------------|------------------------------------------------------------------------|
| PCB                | PC space                                                               |
| DTB                | Data space                                                             |
| ADB                | AD space                                                               |
| SPB                | Either the SSP or USP space is used according to the stack flag value. |

Use the following instructions with care:

String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

The bank register specified by an operand is used regardless of the prefix.

Stack manipulation instructions (PUSHW, POPW)

SSB or USB is used according to the S flag regardless of the prefix.

I/O access instructions

 $MOVA, io/MOVio, A/MOVXA, io/MOVWA, io/MOVWio, A/MOVio, \#imm8 \\ MOVWio, \#imm16/MOVBA, io:bp/MOVBio:bp, A/SETBio:bp/CLRBio:bp \\ BBCio:bp, rel/BBSio:bp, rel/WBTC, WBTS$ 

The IO space of the bank is used regardless of the prefix.

Flag change instructions (AND CCR,#imm8, OR CCR,#imm8)

The instruction is executed normally, but the prefix affects the next instruction.

POPW PS

SSB or USB is used according to the S flag regardless of the prefix. The prefix affects the next instruction.

### MOV ILM,#imm8

The instruction is executed normally, but the prefix affects the next instruction.

### RETI

SSB is used regardless of the prefix.

### ■ Common Register Bank Prefix (CMR)

To simplify data exchange between multiple tasks, the same register bank must be accessed relatively easily regardless of the RP value. When CMR is placed before an instruction that accesses a register bank, the register accessed by that instruction can be changed to the common bank (the register bank selected when RP=0) at addresses from  $000180_{\rm H}$  to  $00018F_{\rm H}$  regardless of the current RP value. Use the following instructions with care:

String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

If an interrupt request occurs during execution of a string instruction with a prefix code, the prefix code becomes invalid when the string instruction is resumed after the interrupt is processed. Thus, the string instruction is executed falsely after the interrupt is processed. Do not prefix any of the above string instructions with CMR.

Flag change instructions (AND CCR,#imm8, OR CCR,#imm8, POPW PS)

The instruction is executed normally, but the prefix affects the next instruction.

MOV ILM,#imm8

The instruction is executed normally, but the prefix affects the next instruction.

### **■** Flag Change Disable Prefix (NCC)

To disable flag changes, use the flag change disable prefix code (NCC). Placing NCC before an instruction that suppresses unnecessary flag change disables flag changes associated with that instruction. Use the following instructions with care:

String instructions (MOVS, MOVSW, SCEQ, SCWEQ, FILS, FILSW)

If an interrupt request occurs during execution of a string instruction with a prefix code, the prefix code becomes invalid when the string instruction is resumed after the interrupt is processed. Thus, the string instruction is executed incorrectly after the interrupt is processed. Do not prefix any of the above string instructions with NCC.

Flag change instructions (AND CCR,#imm8, OR CCR,#imm8, POPW PS)

The instruction is executed normally, but the prefix affects the next instruction.

Interrupt instructions (INT #vct8, INT9, INT addr16, INTP addr24, RETI)

CCR changes according to the instruction specifications regardless of the prefix.

JCTX @A

CCR changes according to the instruction specifications regardless of the prefix.

# CHAPTER 2 CPU

# ● MOV ILM,#imm8

The instruction is executed normally, but the prefix affects the next instruction.

# 2.10 Interrupt Disable Instructions

# Interrupt requests are not sampled for the following ten instructions:

- MOV ILM,#imm8 - PCB - SPB - OR CCR,#imm8 - NCC

- AND CCR,#imm8 - ADB - CMR - POPW PS - DTB

### ■ Interrupt Disable Instructions

If a valid hardware interrupt request occurs during execution of any of the above instructions, the interrupt can be processed only when an instruction other than the above is executed. For details, see Figure 2.10-1.

Figure 2.10-1 Interrupt Disable Instruction



# ■ Restrictions on Interrupt Disable Instructions and Prefix Instructions

When a prefix code is placed before an interrupt disable instruction, the prefix code affects the first instruction after the code other than the interrupt disable instruction. For details, see Figure 2.10-2.

Figure 2.10-2 Interrupt Disable Instructions and Prefix Codes



# **■** Consecutive prefix codes

When competitive prefix codes are placed consecutively, the latter becomes valid.

In the figure below, competitive prefix codes are PCB, ADB, DTB, and SPB. For details, see Figure 2.10-3.

Figure 2.10-3 Consecutive Prefix Codes



# 2.11 Precautions for Use of "DIV A, Ri" and "DIVW A, RWi" Instructions

Set " $00_H$ " in the bank register before using the "DIV A, Ri" and "DIVW A, RWi" instructions.

# ■ Precautions for Use of "DIV A, Ri" and "DIVW A, RWi" Instructions

Table 2.11-1 Precautions for Use of "DIVA,Ri" and "DIVWA,RWi" Instructions (i=0 to 7)

| Instruction | Bank register name affected<br>by the execution of the<br>instructions listed on the left | Address that stores the remainder                                                             |
|-------------|-------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| DIVA,R0     | DTB                                                                                       | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +8 <sub>H</sub> Lower 16 bits)   |
| DIVA,R1     |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +9 <sub>H</sub> Lower 16 bits)   |
| DIVA,R4     |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +C <sub>H</sub> Lower 16 bits)   |
| DIVA,R5     |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +D <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW0   |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +0 <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW1   |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +2 <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW4   |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +8 <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW5   |                                                                                           | (DTB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +A <sub>H</sub> Lower 16 bits)   |
| DIVA,R2     | ADB                                                                                       | (ADB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +A <sub>H</sub> Lower 16 bits)   |
| DIVA,R6     |                                                                                           | (ADB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +E <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW2   |                                                                                           | (ADB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +4 <sub>H</sub> Lower 16 bits)   |
| DIVWA,RW6   |                                                                                           | (ADB: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +E <sub>H</sub> Lower 16 bits)   |
| DIVA,R3     |                                                                                           | (USB*2: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +B <sub>H</sub> Lower 16 bits) |
| DIVA,R7     | USB, SSB <sup>*1</sup>                                                                    | (USB*2: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +F <sub>H</sub> Lower 16 bits) |
| DIVWA,RW3   |                                                                                           | (USB*2: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +6 <sub>H</sub> Lower 16 bits) |
| DIVWA,RW7   |                                                                                           | (USB*2: Upper 8 bits)+(0180 <sub>H</sub> +RP × 10 <sub>H</sub> +E <sub>H</sub> Lower 16 bits) |

<sup>\*1:</sup> Depends on the S bit of the CCR register

If the value of the bank registers (DTB, ADB, USB, and SSB) is " $00_{\rm H}$ ", the remainder after division is stored in the register of the instruction operands. Otherwise, the upper eight bits is specified by the bank register corresponding to the register of the instruction operand, and the lower 16 bits is the same as the address of the register of the instruction operand. The remainder is stored in the bank register specified by the upper eight bits.

<sup>\*2:</sup> In the event that S bit of the CCR register is 0

### **Example:**

If "DIV A,R0" is executed with DTB = " $053_{\rm H}$ " and RP = " $03_{\rm H}$ ", the address of R0 is " $0180_{\rm H}$ " + RP (" $03_{\rm H}$ ") × " $10_{\rm H}$ " + " $08_{\rm H}$ " (R0 corresponding address) = " $000188_{\rm H}$ ". Since the data bank register (DTB) is specified by "DIV A,R0" as the bank register, the remainder is stored in address " $0530188_{\rm H}$ ", which was obtained by adding the bank address " $053_{\rm H}$ ".

#### Note:

For information about the bank register and Ri and RWi registers, see "2.7 Registers".

# ■ Use of the "DIV A, Ri" and "DIVW A, RWi" Instructions without Precautions

To enable users to develop programs without having to take precautions for using the "DIV A,Ri" and "DIVW A,RWi" instructions, special compilers and assemblers are available. The special compiler does not generate the instructions in Table 2.11-1 . The special assemblers have a function that replaces the instructions in Table 2.11-1 with equivalent instruction strings. For the MB90360 series, use the following types of compilers and assemblers:

### Compiler

• cc907 V02L06 or later version, or fcc907s V30L02 or later version

### Assembler

• asm907a V03L04 or later version, or fasm907s V30L04 (Rev. 300004) or later version

# CHAPTER 3 INTERRUPTS

This chapter explains the interrupts and function and operation of the extended intelligent I/O service in the MB90360 series.

- 3.1 Outline of Interrupts
- 3.2 Interrupt Vector
- 3.3 Interrupt Control Registers (ICR)
- 3.4 Interrupt Flow
- 3.5 Hardware Interrupts
- 3.6 Software Interrupts
- 3.7 Extended Intelligent I/O Service (EI<sup>2</sup>OS)
- 3.8 Operation Flow of and Procedure for Using the Extended Intelligent I/O Service (EI<sup>2</sup>OS)
- 3.9 Exceptions

# 3.1 Outline of Interrupts

The F<sup>2</sup>MC-16LX has interrupt functions that terminate the currently executing processing and transfer control to another specified program when a specified event occurs. There are four types of interrupt functions:

- Hardware interrupt: Interrupt processing due to an internal resource event
- Software interrupt: Interrupt processing due to a software event occurrence instruction
- Extended intelligent I/O service (EI<sup>2</sup>OS): Transfer processing due to an internal resource event
- Exception: Termination due to an operation exception

# ■ Hardware Interrupts

A hardware interrupt is activated by an interrupt request from an internal resource. A hardware interrupt request occurs when both the interrupt request flag and the interrupt enable flag in an internal resource are set. Therefore, an internal resource must have an interrupt request flag and interrupt enable flag to issue a hardware interrupt request.

### Specifying an interrupt level

An interrupt level can be specified for the hardware interrupt. To specify an interrupt level, use the level setting bits (IL0, IL1, and IL2) of the interrupt controller.

### Masking a hardware interrupt request

A hardware interrupt request can be masked by using the I flag of the processor status register (PS) in the CPU and the ILM bits (IL0, IL1, and IL2). When an unmasked interrupt request occurs, the CPU saves 12 bytes of data that consists of registers PS, PC, PCB, DTB, ADB, DPR, and A in the memory area indicated by the SSB and SSP registers.

PS: Processor status : Interrupt enable flag Register file PS ILM ILM: Interrupt level mask register IR : Instruction register Micro code Check ΙR Comparator <sup>-2</sup>MC-16LX F2MC-16LX CPU (3) Peripheral comparator level Enable FF nterrupt AND evel. Factor FF Interrupt

Figure 3.1-1 Overview of Hardware Interrupts

## **■** Software Interrupts

Interrupts requested by executing the INT instruction are software interrupts. An interrupt request by the INT instruction does not have an interrupt request or enable flag. An interrupt request is issued always by executing the INT instruction.

No interrupt level is assigned to the INT instruction. Therefore, ILM is not updated when the INT instruction is used. Instead, the I flag is cleared and the continuing interrupt requests are suspended.



Figure 3.1-2 Overview of Software Interrupts

## ■ Extended Intelligent I/O Service (EI<sup>2</sup>OS)

The extended intelligent I/O service automatically transfers data between an internal resource and memory. This processing is traditionally performed by an interrupt processing program, but the EI<sup>2</sup>OS enables data to be transferred in a manner similar to a DMA (direct memory access) operation.

To activate the extended intelligent I/O service function from an internal resource, the interrupt control register (ICR) of the interrupt controller must have an extended intelligent I/O service enable flag (ISE).

The extended intelligent I/O service is started when an interrupt request occurs with 1 specified in the ISE flag. To generate a normal interrupt using a hardware interrupt request, set the ISE flag to 0.



Figure 3.1-3 Overview of the Extended Intelligent I/O Service (EI<sup>2</sup>OS)

## **■** Exceptions

Exception processing is basically the same as interrupt processing. When an exception is detected between instructions, ordinary processing is suspended, and exception processing is performed. In general, exception processing occurs as a result of an unexpected operation. Therefore, use exception processing for debugging programs or for activating recovery software in an emergency.

## 3.2 Interrupt Vector

An interrupt vector uses the same area for both hardware and software interrupts. For example, interrupt request number INT42 is used for a delayed hardware interrupt and for software interrupt INT #42. Therefore, the delayed interrupt and INT #42 call the same interrupt processing routine. Interrupt vectors are allocated between addresses  $\mathsf{FFFC00}_\mathsf{H}$  and  $\mathsf{FFFFF}_\mathsf{H}$  as shown in Table 3.2-1 .

## **■** Interrupt Vector

Table 3.2-1 Interrupt Vector (1/2)

| Interrupt request | Interrupt cause                   | reg    | ot control<br>ister         | Vector<br>address   | Vector<br>address   | Vector<br>address   | Mode<br>register    |
|-------------------|-----------------------------------|--------|-----------------------------|---------------------|---------------------|---------------------|---------------------|
|                   |                                   | Number | Address                     | lower               | middle              | upper               | 0                   |
| INT 0 *           |                                   |        |                             | FFFFFC <sub>H</sub> | FFFFFD <sub>H</sub> | FFFFFE <sub>H</sub> | Unused              |
| INT 1 *           |                                   |        |                             | FFFFF8 <sub>H</sub> | FFFFF9 <sub>H</sub> | FFFFFA <sub>H</sub> | Unused              |
| •                 |                                   |        |                             | •                   |                     | •                   |                     |
|                   |                                   |        |                             |                     |                     |                     |                     |
| INT 7 *           |                                   |        |                             | FFFFE0 <sub>H</sub> | FFFFE1 <sub>H</sub> | FFFFE2 <sub>H</sub> | Unused              |
| INT 8             | Reset                             |        |                             | FFFFDC <sub>H</sub> | FFFFDD <sub>H</sub> | FFFFDE <sub>H</sub> | FFFFDF <sub>H</sub> |
| INT 9             | INT9 instruction                  |        |                             | FFFFD8 <sub>H</sub> | FFFFD9 <sub>H</sub> | FFFFDA <sub>H</sub> | Unused              |
| INT 10            | Exception processing              |        |                             | FFFFD4 <sub>H</sub> | FFFFD5 <sub>H</sub> | FFFFD6 <sub>H</sub> | Unused              |
| INT 11            | Reserved                          | ICR00  | 0000B0 <sub>H</sub>         | FFFFD0 <sub>H</sub> | FFFFD1 <sub>H</sub> | FFFFD2 <sub>H</sub> | Unused              |
| INT 12            | Reserved                          | ICK00  | оооовон                     | FFFFCC <sub>H</sub> | FFFFCD <sub>H</sub> | FFFFCE <sub>H</sub> | Unused              |
| INT 13            | CAN1 reception                    |        |                             | FFFFC8 <sub>H</sub> | FFFFC9 <sub>H</sub> | FFFFCA <sub>H</sub> | Unused              |
| INT 14            | CAN1 transmission/<br>node status | ICR01  | 0000B1 <sub>H</sub>         | FFFFC4 <sub>H</sub> | FFFFC5 <sub>H</sub> | FFFFC6 <sub>H</sub> | Unused              |
| INT 15            | Reserved                          | ICR02  | 0000B2 <sub>H</sub>         | FFFFC0 <sub>H</sub> | FFFFC1 <sub>H</sub> | FFFFC2 <sub>H</sub> | Unused              |
| INT 16            | Reserved                          | ICK02  | 0000B2H                     | FFFFBC <sub>H</sub> | FFFFBD <sub>H</sub> | FFFFBE <sub>H</sub> | Unused              |
| INT 17            | Reserved                          | ICR03  | 0000B3 <sub>H</sub>         | FFFFB8 <sub>H</sub> | FFFFB9 <sub>H</sub> | FFFFBA <sub>H</sub> | Unused              |
| INT 18            | Reserved                          | ICKUS  | 0000ДЗН                     | FFFFB4 <sub>H</sub> | FFFFB5 <sub>H</sub> | FFFFB6 <sub>H</sub> | Unused              |
| INT 19            | 16-bit reload timer 2             | ICD04  | 0000B4 <sub>H</sub>         | FFFFB0 <sub>H</sub> | FFFFB1 <sub>H</sub> | FFFFB2 <sub>H</sub> | Unused              |
| INT 20            | 16-bit reload timer 3             | ICKU4  | ICR04   0000B4 <sub>H</sub> | FFFFAC <sub>H</sub> | FFFFAD <sub>H</sub> | FFFFAE <sub>H</sub> | Unused              |
| INT 21            | Reserved                          | ICR05  | 0000B5 <sub>H</sub>         | FFFFA8 <sub>H</sub> | FFFFA9 <sub>H</sub> | FFFFAA <sub>H</sub> | Unused              |
| INT 22            | Reserved                          | ICKUS  | Нсполо                      | FFFFA4 <sub>H</sub> | FFFFA5 <sub>H</sub> | FFFFA6 <sub>H</sub> | Unused              |
| INT 23            | PPG C/D                           | ICR06  | 0000B6 <sub>H</sub>         | FFFFA0 <sub>H</sub> | FFFFA1 <sub>H</sub> | FFFFA2 <sub>H</sub> | Unused              |
| INT 24            | PPG E/F                           | ICKUO  | OOOOBOH                     | FFFF9C <sub>H</sub> | FFFF9D <sub>H</sub> | FFFF9E <sub>H</sub> | Unused              |

Table 3.2-1 Interrupt Vector (2/2)

| Interrupt<br>request | Interrupt cause                     | Interrupt control register  Number Address |                     | Vector<br>address<br>lower | Vector<br>address<br>middle | Vector<br>address<br>upper | Mode<br>register |
|----------------------|-------------------------------------|--------------------------------------------|---------------------|----------------------------|-----------------------------|----------------------------|------------------|
| INT 25               | Timebase timer 3                    | Number                                     | Address             | FFFF98 <sub>H</sub>        | FFFF99 <sub>H</sub>         | FFFF9A <sub>H</sub>        | Unused           |
|                      |                                     | ICR07                                      | 0000B7 <sub>H</sub> | 111190Н                    | тттээн                      | тттулн                     | Unused           |
| INT 26               | External interrupt 8 to 11          | ICK07                                      | 0000B/H             | FFFF94 <sub>H</sub>        | FFFF95 <sub>H</sub>         | FFFF96 <sub>H</sub>        | Unused           |
| INT 27               | Watch timer                         |                                            |                     | FFFF90 <sub>H</sub>        | FFFF91 <sub>H</sub>         | FFFF92 <sub>H</sub>        | Unused           |
| INT 28               | External interrupt 12 to 15         | ICR08                                      | 0000B8 <sub>H</sub> | FFFF8C <sub>H</sub>        | FFFF8D <sub>H</sub>         | FFFF8E <sub>H</sub>        | Unused           |
| INT 29               | A/D converter                       | ICDOO                                      | 0000B9 <sub>H</sub> | FFFF88 <sub>H</sub>        | FFFF89 <sub>H</sub>         | FFFF8A <sub>H</sub>        | Unused           |
| INT 30               | I/O timer 0                         | ICR09                                      | ООООБЭН             | FFFF84 <sub>H</sub>        | FFFF85 <sub>H</sub>         | FFFF86 <sub>H</sub>        | Unused           |
| INT 31               | Reserved                            | ICD10                                      | 0000D A             | FFFF80 <sub>H</sub>        | FFFF81 <sub>H</sub>         | FFFF82 <sub>H</sub>        | Unused           |
| INT 32               | Reserved                            | ICR10                                      | 0000BA <sub>H</sub> | FFFF7C <sub>H</sub>        | FFFF7D <sub>H</sub>         | FFFF7E <sub>H</sub>        | Unused           |
| INT 33               | Input capture 0 to 3                | ICD 11                                     | 0000BB <sub>H</sub> | FFFF78 <sub>H</sub>        | FFFF79 <sub>H</sub>         | FFFF7A <sub>H</sub>        | Unused           |
| INT 34               | Reserved                            | - ICR11                                    | ООООВВН             | FFFF74 <sub>H</sub>        | FFFF75 <sub>H</sub>         | FFFF76 <sub>H</sub>        | Unused           |
| INT 35               | UART 0 reception                    | ICD 12                                     | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub>        | FFFF71 <sub>H</sub>         | FFFF72 <sub>H</sub>        | Unused           |
| INT 36               | UART 0 transmission                 | ICR12                                      | оооовсн             | FFFF6C <sub>H</sub>        | FFFF6D <sub>H</sub>         | FFFF6E <sub>H</sub>        | Unused           |
| INT 37               | UART 1 reception                    | ICR13                                      | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub>        | FFFF69 <sub>H</sub>         | FFFF6A <sub>H</sub>        | Unused           |
| INT 38               | UART 1 transmission                 | ICKIS                                      | ин                  | FFFF64 <sub>H</sub>        | FFFF65 <sub>H</sub>         | FFFF66 <sub>H</sub>        | Unused           |
| INT 39               | Reserved                            | ICR14                                      | 0000BE <sub>H</sub> | FFFF60 <sub>H</sub>        | FFFF61 <sub>H</sub>         | FFFF62 <sub>H</sub>        | Unused           |
| INT 40               | Reserved                            | ICK14                                      | оооовен             | FFFF5C <sub>H</sub>        | FFFF5D <sub>H</sub>         | FFFF5E <sub>H</sub>        | Unused           |
| INT 41               | Flash memory                        |                                            |                     | FFFF58 <sub>H</sub>        | FFFF59 <sub>H</sub>         | FFFF5A <sub>H</sub>        | Unused           |
| INT 42               | Delayed interrupt generation module | ICR15                                      | 0000BF <sub>H</sub> | FFFF54 <sub>H</sub>        | FFFF55 <sub>H</sub>         | FFFF56 <sub>H</sub>        | Unused           |
| INT 43               |                                     |                                            |                     | FFFF50 <sub>H</sub>        | FFFF51 <sub>H</sub>         | FFFF52 <sub>H</sub>        | Unused           |
|                      |                                     |                                            |                     |                            |                             | •                          |                  |
|                      |                                     |                                            |                     |                            |                             |                            |                  |
| INT 254              |                                     |                                            |                     | FFFC04 <sub>H</sub>        | FFFC05 <sub>H</sub>         | FFFC06 <sub>H</sub>        | Unused           |
| INT 255              |                                     |                                            |                     | FFFC00 <sub>H</sub>        | FFFC01 <sub>H</sub>         | FFFC02 <sub>H</sub>        | Unused           |

<sup>\*:</sup> When PCB is FF<sub>H</sub>, the vector area for the CALLV instruction overlaps that for INT #vct8 (#0 to #7). Care must be taken when using the CALLV instruction.

#### **Interrupt Control Registers (ICR)** 3.3

The interrupt control registers are in the interrupt controller. Each interrupt control register has a corresponding I/O that has an interrupt function. The interrupt control registers have the following 3 functions:

- Setting an interrupt level for corresponding peripherals
- Selecting whether to use an ordinary interrupt or extended intelligent I/O service for the corresponding peripherals
- Selecting the extended intelligent I/O service channel Do not access an interrupt control register by using a read-modify-write instruction, as doing so causes a misoperation.

## ■ Interrupt Control Register (ICR)

Figure 3.3-1 is a diagram of the bit configuration of an interrupt control register.

15/7 14/6 13/5 12/4 11/3 10/2 9/1 8/0 Interrupt control ICS3 ICS2 ICS1 ICS<sub>0</sub> ISE IL2 IL1 IL0 register or or00000111в S1 S0 when reset W R/W R/W R/W R/W \*: '1' is read always.

Figure 3.3-1 Interrupt Control Register (ICR)

ICS1 and ICS0 are valid for write only. S1 and S0 are valid for read only.

#### Note:

ICS3 to ICS0 are valid only when El<sup>2</sup>OS is activated. Set '1' in ISE to activate El<sup>2</sup>OS, and set '0' in ISE not to activate it. When EI<sup>2</sup>OS is not to be activated, any value can be set in ICS3 to ICS0.

## [bit 10 to bit 8, bit 2 to bit 0] IL0, IL1, and IL2 (interrupt level setting bits)

These bits are readable and writable and specify the interrupt level of the corresponding internal resources. Upon a reset, these bits are initialized to level 7 (no interrupt). Table 3.3-1 describes the relationship between the interrupt level setting bits and interrupt levels.

Table 3.3-1 Interrupt Level Setting Bits and Interrupt Levels

| ILM2 | ILM1 | ILM0 | Level            |
|------|------|------|------------------|
| 0    | 0    | 0    | 0 (strongest)    |
| 0    | 0    | 1    | 1                |
| 0    | 1    | 0    | 2                |
| 0    | 1    | 1    | 3                |
| 1    | 0    | 0    | 4                |
| 1    | 0    | 1    | 5                |
| 1    | 1    | 0    | 6 (weakest)      |
| 1    | 1    | 1    | 7 (no interrupt) |

[bit 11, bit 3] ISE (extended intelligent I/O service enable bits)

The ISE bit is readable and writable. In response to an interrupt request, EI<sup>2</sup>OS is activated when '1' is set in the ISE bit and an interrupt sequence is activated when '0' is set in the ISE bit. Upon completion of EI<sup>2</sup>OS, the ISE bit is cleared to a zero. If the corresponding peripheral does not have the EI<sup>2</sup>OS function, the ISE bit must be set to '0' on the software side.

Upon a reset, the ISE bit is initialized to '0'.

[bit 15 to bit 12, bit 7 to bit 4] ICS 3 to ICS 0 (extended intelligent I/O service channel select bits)

ICS3 to ICS0 are write-only bits. These bits specify the  $\rm EI^2OS$  channel. The values set in these bits determined the extended intelligent I/O service descriptor addresses in memory, which is explained later. The ICS bits are initialized to "0000<sub>B</sub>" by a reset.

Table 3.3-2 describes the correspondence between the ICS bits, channel numbers, and descriptor addresses.

Table 3.3-2 ICS Bits, Channel Numbers, and Descriptor Address

| ICS3 | ICS2 | ICS1 | ICS0 | Selected channel | Descriptor address  |
|------|------|------|------|------------------|---------------------|
| 0    | 0    | 0    | 0    | 0                | 000100 <sub>H</sub> |
| 0    | 0    | 0    | 1    | 1                | 000108 <sub>H</sub> |
| 0    | 0    | 1    | 0    | 2                | 000110 <sub>H</sub> |
| 0    | 0    | 1    | 1    | 3                | 000118 <sub>H</sub> |
| 0    | 1    | 0    | 0    | 4                | 000120 <sub>H</sub> |
| 0    | 1    | 0    | 1    | 5                | 000128 <sub>H</sub> |
| 0    | 1    | 1    | 0    | 6                | 000130 <sub>H</sub> |
| 0    | 1    | 1    | 1    | 7                | 000138 <sub>H</sub> |
| 1    | 0    | 0    | 0    | 8                | 000140 <sub>H</sub> |
| 1    | 0    | 0    | 1    | 9                | 000148 <sub>H</sub> |
| 1    | 0    | 1    | 0    | 10               | 000150 <sub>H</sub> |
| 1    | 0    | 1    | 1    | 11               | 000158 <sub>H</sub> |
| 1    | 1    | 0    | 0    | 12               | 000160 <sub>H</sub> |
| 1    | 1    | 0    | 1    | 13               | 000168 <sub>H</sub> |
| 1    | 1    | 1    | 0    | 14               | 000170 <sub>H</sub> |
| 1    | 1    | 1    | 1    | 15               | 000178 <sub>H</sub> |

[bit 13, bit 12, bits 5, bit 4] S0 and S1 (extended intelligent I/O service status)

S0 and S1 are read-only bits. The values set in these bits indicate the end condition of  $EI^2OS$ . These bits are initialized to '00' upon a reset.

Table 3.3-3 shows the relationship between the S bits and the end conditions.

Table 3.3-3 S Bits and End Conditions

| S1 | S0 | End conditions                                |
|----|----|-----------------------------------------------|
| 0  | 0  | EI <sup>2</sup> OS running or not activated   |
| 0  | 1  | Stop status by count end                      |
| 1  | 0  | Reserved                                      |
| 1  | 1  | Stop status by request from internal resource |

## 3.4 Interrupt Flow

## Figure 3.4-1 shows the interrupt flow.

## **■** Interrupt Flow

Figure 3.4-1 Interrupt Flow





Figure 3.4-2 Register Saving during Interrupt Processing

## 3.5 Hardware Interrupts

In response to an interrupt request signal from an internal resource, the CPU pauses current program execution and transfers control to the interrupt processing program defined by the user. This function is called the hardware interrupt function.

## ■ Hardware Interrupts

A hardware interrupt occurs when the relevant conditions are satisfied as a result of two operations: comparison between the interrupt request level and the value in the interrupt level mask register (ILM) of PS in the CPU, and hardware reference to the I flag value of PS.

The CPU performs the following processing when a hardware interrupt occurs:

- Saves the values in the PC, PS, AH, AL, PCB, DTB, ADB, and DPR registers of the CPU to the system stack.
- Sets ILM in the PS register. The currently requested interrupt level is automatically set.
- Fetches the corresponding interrupt vector value and branches to the processing indicated by that value.

## ■ Structure of Hardware Interrupt

Hardware interrupts are handled by the following 3 sections:

#### Internal resources

Interrupt enable and request bits: Used to control interrupt requests from resources.

#### Interrupt controller

ICR: Assigns interrupt levels and determines the priority levels of simultaneously requested interrupts.

#### CPU

I and ILM: Used to compare the requested and current interrupt levels and to identify the interrupt enable status.

Microcode: Interrupt processing step

The status of these sections are indicated by the resource control registers for internal resources, the ICR for the interrupt controller, and the CCR value for the CPU. To use a hardware interrupt, set the three sections beforehand by using software.

The interrupt vector table referred during interrupt processing is assigned to addresses  $FFFC00_H$  to  $FFFFFF_H$  in memory. These addresses are shared with software interrupts.

"Table D-2 Interrupt Causes, Interrupt Vectors, and Interrupt Control Registers" in "APPENDIX D List of Interrupt Vectors" shows the assignment of the MB90360 series.

## 3.5.1 Hardware Interrupt Operation

An internal resource that has the hardware interrupt request function has an interrupt request flag and interrupt enable flag. The interrupt request flag indicates whether an interrupt request exists, and the interrupt enable flag indicates whether the relevant internal resource requests an interrupt to the CPU. The interrupt request flag is set when an event that is unique to the internal resource occurs. When the interrupt enable flag indicates "enable", the resource issues an interrupt request to the interrupt controller.

## ■ Hardware Interrupt Operation

When two or more interrupt requests are received at the same time, the interrupt controller compares the interrupt levels (IL) in ICR, selects the request at the highest level (the smallest IL value), then reports that request to the CPU. If multiple requests are at the same level, the interrupt controller selects the request with the lowest interrupt number. The relationship between the interrupt requests and ICRs is determined by the hardware.

The CPU compares the received interrupt level (IL) and the ILM in the PS register. If the interrupt level is smaller than the ILM value and the I bit of the PS register is set to '1', the CPU activates the interrupt processing microcode after the currently executing instruction is completed. The CPU refers the ISE bit of the ICR of the interrupt controller at the beginning of the interrupt processing microcode, checks that the ISE bit is 0 (interrupt), and activates the interrupt processing body.

The interrupt processing body saves 12 bytes (PS, PC, PCB, DTB, ADB, DPR, and A) to the memory area indicated by SSB and SSP, fetches 3 bytes of interrupt vector, loads them onto PC and PCB, updates the ILM of PS to a level value of the received interrupt request, sets the S flag, then performs branch processing. As a result, the interrupt processing program defined by the user is executed next.

## 3.5.2 Occurrence and Release of Hardware Interrupt

Figure 3.5-1 shows the processing flow from occurrence of a hardware interrupt to release of the interrupt request in an interrupt processing program.

## **■** Occurrence and Release of Hardware Interrupt



- 1. An interrupt cause occurs in a peripheral.
- 2. The interrupt enable bit in the peripheral is referred. If interrupts are enabled, the peripheral issues an interrupt request to the interrupt controller.
- 3. Upon reception of the interrupt request, the interrupt controller determines the priority levels of simultaneously requested interrupts. Then, the interrupt controller transfers the interrupt level of the corresponding interrupt to the CPU.
- 4. The CPU compares the interrupt level requested by the interrupt controller with the ILM bit of the processor status register.
- 5. If the comparison shows that the requested level is higher than the current interrupt processing level, the I flag value of the same processor status register is checked.
- 6. If the check in step 5. shows that the I flag indicates interrupt enable status, the requested level is written to the ILM bit. Interrupt processing is performed as soon as the currently executing instruction is completed, then control is transferred to the interrupt processing routine.
- 7. When the interrupt cause of step 1. is cleared by software in the user interrupt processing routine, the interrupt request is completed.

## CHAPTER 3 INTERRUPTS

The time required for the CPU to execute the interrupt processing in steps 6. and 7. is shown below. See Table 3.5-1 for the cycle count compensation value.

Interrupt start:  $24 + 6 \times (Table 3.3-2 machine cycles)$ 

Interrupt return:  $15 + 6 \times \text{(Table 3.3-2 machine cycles)}$  RETI instruction

**Table 3.5-1 Compensation Values for Interrupt Processing Cycle Count** 

| Address indicated by stack pointer | Cycle count compensation value |
|------------------------------------|--------------------------------|
| Internal area, even-number address | 0                              |
| Internal area, add-number address  | +2                             |

## 3.5.3 Multiple interrupts

As a special case, no hardware interrupt request can be accepted while data is being written to the I/O area. This is intended to prevent the CPU from operating falsely because of an interrupt request issued while an interrupt control register for a resource is being updated.

If an interrupt occurs during interrupt processing, a higher-level interrupt is processed first.

## **■** Multiple Interrupts

The F<sup>2</sup>MC-16LX CPU supports multiple interrupts. If an interrupt of a higher level occurs while another interrupt is being processed, control is transferred to the high-level interrupt after the currently executing instruction is completed. After processing of the high-level interrupt is completed, the original interrupt processing is resumed. An interrupt of the same or lower level may be generated while another interrupt is being processed. If this happens, the new interrupt request is suspended until the current interrupt processing is completed, unless the ILM value or I flag is changed by an instruction. The extended intelligent I/O service cannot be activated from multiple sources; while an extended intelligent I/O service is being processed, all other interrupt requests or extended intelligent I/O service requests are suspended.

Figure 3.5-2 shows the order of the registers saved in the stack.



Figure 3.5-2 Registers Saved in Stack

## 3.6 Software Interrupts

In response to execution of a special instruction, control is transferred from the program currently executed by the CPU to the interrupt processing program defined by the user. This is called the software interrupt function. A software interrupt occurs always when the software interrupt instruction is executed.

## ■ Software Interrupts

The CPU performs the following processing when a software interrupt occurs:

- Saves the values in the PC, PS, AH, AL, PCB, DTB, ADB, and DPR registers of the CPU to the system stack.
- Sets I in the PS register. Interrupts are automatically disabled.
- Fetches the corresponding interrupt vector value, then branches to the processing indicated by that value.

A software interrupt request issued by the INT instruction has no interrupt request or enable flag. A software interrupt request is always issued by executing the INT instruction.

The INT instruction does not have an interrupt level. Therefore, the INT instruction does not update ILM. The INT instruction clears the I flag to suspend subsequent interrupt requests.

## **■** Structure of Software Interrupts

Software interrupts are handled within the CPU:

CPU....Microcode: Interrupt processing step

### **■** List of Interrupt Vectors

"Table D-1 Interrupt Vectors" in APPENDIX D lists the interrupt vectors of the MB90360 series.

Software interrupts share the same interrupt vector area with hardware interrupts.

For example, interrupt request number INT 12 is used for external interrupt #0 to #7 of a hardware interrupt as well as for INT #12 of a software interrupt. Therefore, external interrupt #0 and INT #12 call the same interrupt processing routine.

#### ■ Software Interrupt Operation

When the CPU fetches and executes the software interrupt instruction, the software interrupt processing microcode is activated. The software interrupt processing microcode saves 12 bytes (PS, PC, PCB, DTB, ADB, DPR, and A) to the memory area indicated by SSB and SSP. The microcode then fetches 3 bytes of interrupt vector and loads them onto PC and PCB, resets the I flag, and sets the S flag. Then, the microcode performs branch processing. As a result, the interrupt processing program defined by the user application program is executed next.

Figure 3.6-1 illustrates the flow from the occurrence of a software interrupt until there is no interrupt request in the interrupt processing program.



Figure 3.6-1 Occurrence and Release of Software Interrupt

- (1) The software interrupt instruction is executed.
- (2) Special CPU registers in the register file are saved according to the microcode corresponding to the software interrupt instruction.
- (3) The interrupt processing is completed with the RETI instruction in the user interrupt processing routine.

#### ■ Others

When the program bank register (PCB) is  $FF_H$ , the CALLV instruction vector area overlaps the table of the INT #vct8 instruction. When designing software, ensure that the CALLV instruction does not use the same address as that of the #vct8 instruction.

"Table D-2 Interrupt Causes, Interrupt Vectors, and Interrupt Control Registers" in APPENDIX D shows the relationship of interrupt cause, interrupt vector, and interrupt control register in the MB90360 series.

## 3.7 Extended Intelligent I/O Service (EI<sup>2</sup>OS)

The El<sup>2</sup>OS function, a kind of hardware interrupt operation, automatically transfers data between input and output and memory. An interrupt processing program was conventionally used for such processing, but El<sup>2</sup>OS enables data transfer to be performed like DMA (direct memory access).

## ■ Extended Intelligent I/O Service (El<sup>2</sup>OS)

EI<sup>2</sup>OS has the following advantages over the conventional method:

- The program size can be small because it is not necessary to write a transfer program.
- No internal register is used for transfer, eliminating the need for register saving and increasing the transfer speed.
- Transfer can be terminated from I/O, preventing unnecessary data from being transferred.
- The buffer address may either be incremented or left unupdated.
- The I/O register address may either be incremented or left unupdated (buffer address is update).

At the end of EI<sup>2</sup>OS, processing automatically branches to an interrupt processing routine after the end condition is set. Thus, the user can identify the end condition.

To implement EI<sup>2</sup>OS, the hardware is distributed in two blocks. Each block has the following registers and descriptors.

- Interrupt control register: Exists in the interrupt controller and indicates the ISD address.
- Extended intelligent I/O service descriptor (ISD): Exists in RAM and holds the transfer mode, I/O address, number of transfers, and buffer address.

Figure 3.7-1 outlines the extended intelligent I/O service.



Figure 3.7-1 Outline of Extended Intelligent I/O Service

#### Note:

- The area that can be specified by IOA is between 000000<sub>H</sub> and 00FFFF<sub>H</sub>.
- The area that can be specified by BAP is between 000000<sub>H</sub> and FFFFFF<sub>H</sub>.
- The maximum transfer count that can be specified by DCT is 65,536.

#### **■** Structure

EI<sup>2</sup>OS is handled by the following 4 sections:

#### **Internal resources**

Interrupt enable and request bits: Used to control interrupt requests from resources.

#### **Interrupt controller**

ICR: Assigns interrupt levels, determines the priority levels of simultaneously requested interrupts, and selects the  $\mathrm{EI}^2\mathrm{OS}$  operation.

### **CPU**

I and ILM: Used to compare the requested and current interrupt levels and to identify the interrupt enable status

Microcode: EI<sup>2</sup>OS processing step

#### **RAM**

Descriptor: Describes the EI<sup>2</sup>OS transfer information.

## 3.7.1 Extended Intelligent I/O Service Descriptor (ISD)

The extended intelligent I/O service descriptor exists between  $000100_{\rm H}$  and  $00017F_{\rm H}$  in internal RAM and consists of the following items:

- Data transfer control data
- Status data
- Buffer address pointer

## **■** Extended Intelligent I/O Service Descriptor (ISD)

Figure 3.7-2 shows the configuration of the extended intelligent I/O service descriptor.

Figure 3.7-2 Extended Intelligent I/O Service Descriptor Configuration



## ■ Data Counter (DCT)

This is a 16-bit register that works as a counter corresponding to the number of data items transferred. This counter is decremented by one before data transfer. EI<sup>2</sup>OS is terminated when this counter reaches 0. Figure 3.7-3 is a diagram of the data counter configuration.

Figure 3.7-3 Data Counter Configuration



## ■ I/O register address pointer (IOA)

This is a 16-bit register that indicates the low-order address (A15 to A0) of the buffer and I/O register used for data transfer. The high-order address (A23 to A16) are all zeroes, and any I/O between addresses  $000000_H$  and  $00FFFF_H$  can be specified. Figure 3.7-4 is a diagram of the IOA configuration.

Figure 3.7-4 I/O Register Address Pointer Configuration



## **■** Buffer Address Pointer (BAP)

This 24-bit register holds the address used for the next  $EI^2OS$  transfer. BAP exists for each  $EI^2OS$  channel. Therefore, each  $EI^2OS$  channel can be used for transfer with anywhere in the 16M bytes space. If the BF bit of ISCS is set to '0' (update enabled), only the low-order 16 bits of BAP changes and BAPH does not change.

## 3.7.2 El<sup>2</sup>OS Status Register (ISCS)

This eight-bit register indicates the update direction (increment/decrement), transfer data format (byte/word), and transfer direction of the buffer address pointer and the I/O register address pointer. This register also indicates whether the buffer address pointer or I/O register address pointer is updated or fixed.

## ■ El<sup>2</sup>OS Status Register (ISCS)

Figure 3.7-5 is a diagram of the ISCS configuration.

Be sure to write "0" in bit 7 to bit 5 of ISCS.

Figure 3.7-5 ISCS Configuration

| 7        | 6        | 5        | 4  | 3  | 2  | 1   | 0  |                    |
|----------|----------|----------|----|----|----|-----|----|--------------------|
| Reserved | Reserved | Reserved | IF | BW | BF | DIR | SE | ISCS<br>(Undefined |
|          |          | ,        |    |    |    |     |    | when reset)        |

Each bit is described below.

[bit 4] IF: Specify whether the I/O register address pointer is updated or fixed.

0: The I/O register address pointer is updated after data transfer.

1: The I/O register address pointer is not updated after data transfer.

#### Note:

Only increment is allowed.

[bit 3] BW: Specify the transfer data length.

0: Byte

1: Word

[bit 2] BF: Specify whether the buffer address pointer is updated or fixed.

0: The buffer address pointer is updated after data transfer.

1: The buffer address pointer is not updated after data transfer.

#### Note:

Only the low-order 16 bits of the buffer address pointer are updated. Only increment is allowed.

[bit 1] DIR: Specify the data transfer direction.

0: I/O --> Buffer

1: Buffer --> I/O

[bit 0] SE: Control the termination of the extended intelligent I/O service based on internal resource requests.

0: The extended intelligent I/O service is not terminated by a internal resource request.

1: The extended intelligent I/O service is terminated by a internal resource request.

# 3.8 Operation Flow of and Procedure for Using the Extended Intelligent I/O Service (EI<sup>2</sup>OS)

Figure 3.8-1 is a diagram of the El<sup>2</sup>OS operation flow. Figure 3.8-2 is a diagram of the El<sup>2</sup>OS use procedure.

## **■** El<sup>2</sup>OS Operation Flow

Figure 3.8-1 El<sup>2</sup>OS Operation Flow Buffer address pointer I/OA : I/O address pointer ISD El<sup>2</sup>OS descripter ISCS EI2OS status DCT Data counter Interrupt request issued ISE El<sup>2</sup>OS enable bit S1 and S0: El<sup>2</sup>OS end status from internal resource ISE = 1 YES Interrupt sequence Reading ISD/ISCS YES End request from resource SE = YES DIR = 1 NO Data indicated by BAF

Under the property (Data transfer) Data indicated by IOA

↓ (Data transfer)

Memory indicated by BAP Memory indicated by IOA YES IF = 0NO Update value Updating IOA depends on BW. YES BF = 0 NO Update value **Updating BAP** depends on BW. Decrementing DCT YES Setting S1 and S0 NO Setting S1 and S0 to "01' to "11" Setting S1 and S0 to "00" Clearing resource Clearing ISE to "0" interrupt request CPU operation return Interrupt sequence



Figure 3.8-2 El<sup>2</sup>OS Use Flow

The extended EI<sup>2</sup>OS execution time for each flow is described below.

When data transfer continues (when the stop condition is not satisfied)

When a stop request is issued from a resource

$$(36 + 6 \times Table 3.5-1)$$
 machine cycles

When the counting is completed

(Table 
$$3.8-1 + Table 3.8-2 + (21 + 6 \times Table 3.5-1$$
) machine cycles

Table 3.8-1 Execution Time when the El<sup>2</sup>OS Continues

| ISCS SE bit            | Set to "0" |         | Set to "1" |         |    |
|------------------------|------------|---------|------------|---------|----|
| I/O address pointer    | Fixed      | Updated | Fixed      | Updated |    |
| Buffer address pointer | Fixed      | 32      | 34         | 33      | 35 |
| Burier address pointer | Updated    | 34      | 36         | 35      | 37 |

Table 3.8-2 Data Transfer Compensation Values for El<sup>2</sup>OS Execution Time

| I/O add                | Internal access |     |    |    |
|------------------------|-----------------|-----|----|----|
| I/O add                | B/E             | 0   |    |    |
| Ruffer address pointer | Internal        | B/E | 0  | +2 |
| Buffer address pointer | access          | 0   | +2 | +4 |

B: Byte data transfer

E: Even address word transfer

O: Odd address word transfer

Table 3.8-3 Interrupt Handling Time

| Address pointed to by the stack pointer | Compensation value [cycle] |
|-----------------------------------------|----------------------------|
| External 8 bits                         | +4                         |
| External even-numbered address          | +1                         |
| External odd-numbered address           | +4                         |
| Internal even-numbered address          | 0                          |
| Internal odd-numbered address           | +2                         |

## 3.9 Exceptions

## The $F^2MC-16LX$ performs exception processing when the following event occurs:

#### ■ Execution of an Undefined Instruction

Exception processing is fundamentally the same as interrupt processing. When an exception is detected between instructions, exception processing is performed separately from ordinary processing. In general, exception processing is performed as a result of an unexpected operation. Fujitsu recommends using exception processing for debugging or for activating emergency recovery software.

## **■** Exception Due to Execution of an Undefined Instruction

The F<sup>2</sup>MC-16LX handles all codes that are not defined in the instruction map as undefined instructions. When an undefined instruction is executed, processing equivalent to the INT 10 software interrupt instruction is performed. Specifically, the AL, AH, DPR, DTB, ADB, PCB, PC, and PS values are saved into the system stack, and processing branches to the routine indicated by the interrupt number 10 vector. In addition, the I flag is cleared and the S flag is set. The PC value saved in the stack is the address at which the undefined instruction is stored. Processing can be restored by the RETI instruction, but is of no use, however, because the same exception occurs again.

## CHAPTER 4

# DELAYED INTERRUPT GENERATION MODULE

This chapter explains the functions and operations of the delayed interrupt generation module.

- 4.1 Overview of Delayed Interrupt Generation Module
- 4.2 Block Diagram of Delayed Interrupt Generation Module
- 4.3 Configuration of Delayed Interrupt Generation Module
- 4.4 Explanation of Operation of Delayed Interrupt Generation Module
- 4.5 Precautions when Using Delayed Interrupt Generation Module
- 4.6 Program Example of Delayed Interrupt Generation Module

## 4.1 Overview of Delayed Interrupt Generation Module

The delayed interrupt generation module generates the interrupt for task switching. The hardware interrupt request can be generated/cancelled by software.

## ■ Overview of Delayed Interrupt Generation Module

By using the delayed interrupt generation module, a hardware interrupt request can be generated or cancelled by software.

Table 4.1-1 shows the overview of the delayed interrupt generation module.

**Table 4.1-1 Overview of Delayed Interrupt Generation Module** 

|                    | Function and control                                                                                                                                                                                                                                                                |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Interrupt factor   | An interrupt request is generated by setting the R0 bit in the delayed interrupt request generate/cancel register to 1 (DIRR: $R0 = 1$ ). An interrupt request is cancelled by setting the R0 bit in the delayed interrupt request generate/cancel register to 0 (DIRR: $R0 = 0$ ). |
| Interrupt number   | #42 (2A <sub>H</sub> )                                                                                                                                                                                                                                                              |
| Interrupt control  | An interrupt is not enabled by the DIRR register.                                                                                                                                                                                                                                   |
| Interrupt flag     | The interrupt flag is held in the R0 bit in the DIRR register.                                                                                                                                                                                                                      |
| EI <sup>2</sup> OS | The DIRR register does not correspond to the EI <sup>2</sup> OS.                                                                                                                                                                                                                    |

## 4.2 Block Diagram of Delayed Interrupt Generation Module

The delayed interrupt generation module consists of the following blocks:

- Interrupt request latch
- Delayed interrupt request generate/cancel register (DIRR)

## ■ Block Diagram of Delayed Interrupt Generation Module

Figure 4.2-1 Block Diagram of Delayed Interrupt Generation Module



## Interrupt request latch

This latch keeps the settings (delayed interrupt request generation or cancellation) of the delayed interrupt request generate/cancel register (DIRR).

Delayed interrupt request generate/cancel register (DIRR)

This register generates or cancels a delayed interrupt request.

## **■** Interrupt Number

The interrupt number used in the delayed interrupt generation module is as follows:

Interrupt number #42(2A<sub>H</sub>)

## 4.3 Configuration of Delayed Interrupt Generation Module

This section lists registers and reset values in the delayed interrupt generation module.

## **■** List of Registers and Reset Values

Figure 4.3-1 List of Registers and Reset Values in Delayed Interrupt Generation Module

Delayed interrupt request generate/cancel bit 15 14 13 12 11 10 9 8
register (DIRR)
Address: 00009F<sub>H</sub>

× :Undefined

# 4.3.1 Delayed interrupt request generate/cancel register (DIRR)

The delayed interrupt request generate/cancel register (DIRR) generates or cancels a delayed interrupt request.

## ■ Delayed Interrupt Request Generate/cancel Register (DIRR)





Table 4.3-1 Functions of Delayed Interrupt Request Generate/Cancel Register (DIRR)

|                     | Bit name                                         | Function                                                                                                                                                             |
|---------------------|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit8                | R0:<br>Delayed interrupt<br>request generate bit | This bit generates or cancels a delayed interrupt request.  When set to "0": Cancels delayed interrupt request  When set to "1": Generates delayed interrupt request |
| bit9<br>to<br>bit15 | Undefined bits                                   | Read: The value is undefined. Write: No effect                                                                                                                       |

## 4.4 Explanation of Operation of Delayed Interrupt Generation Module

The delayed interrupt generation module has a function for generating or canceling an interrupt request by software.

## **■** Explanation of Operation of Delayed Interrupt Generation Module

Using the delayed interrupt generation module requires the setting shown in Figure 4.4-1.

Figure 4.4-1 Setting for Delayed Interrupt Generation Module



When the R0 bit in the delayed interrupt request generate/cancel register (DIRR) is set to "1" (DIRR: R0 = 1), an interrupt request is generated. There is no interrupt request enable bit.

## Operation of delayed interrupt generation module

- When the R0 bit in the delayed interrupt request generate/cancel register (DIRR) is set to "1", the interrupt request latch is set to "1" and an interrupt request is generated to the interrupt controller.
- An interrupt request is generated to the CPU when the interrupt controller prioritizes the interrupt request over other requests.
- When the interrupt level mask bit of the condition code register (CCR: ILM) is compared to the interrupt request level (ICR: IL), and the interrupt request level is higher than ILM, CPU executes the delayed interrupt processing after the instruction currently being executed is completed.
- At interrupt processing, the user program sets the R0 bit to 0 to cancel the interrupt request and performs task switching.

Figure 4.4-2 shows the operation of the delayed interrupt generation module.

Figure 4.4-2 Operation of Delayed Interrupt Generation Module



# 4.5 Precautions when Using Delayed Interrupt Generation Module

This section explains the precautions when using the delayed interrupt generation module.

## ■ Precautions when Using Delayed Interrupt Generation Module

- The interrupt processing is restarted at return from interrupt processing without setting the R0 bit in the delayed interrupt request generate/cancel register (DIRR) to "0" within the interrupt processing routine.
- Unlike software interrupts, interrupts in the delayed interrupt generation module are delayed.

## 4.6 Program Example of Delayed Interrupt Generation Module

This section gives a program example of the delayed interrupt generation module.

## ■ Program Example of Delayed Interrupt Generation Module

## Processing specification

The main program writes "1" to the R0 bit in the delayed interrupt request generate/cancel register (DIRR) to generate a delayed interrupt request and performs task switching.

#### Coding example

```
ICR15
                          ;Interrupt control register
      EQU
             0000BFH
DIRR
      EQU
             00009FH
                         ;Delayed interrupt factor generate/
                           cancel register
          DIRR:0
DIRR RO EQU
                          ;Delay interrupt request generating bit
;-----Main program------
CODE
      CSEG
START:
                          ;Stack pointer (SP), already initialized
      AND
             CCR, #0BFH
                         ;Interrupt disabled
      MOV
             I:ICR15,#00H ;Interrupt level 0 (strong)
             ILM, #07H ;Setting ILM in PS to level 7
      VOM
             CCR, #40H
                         ; Interrupt enabled
      OR
             I:DIRR R0
                         ;Delay interrupt request generating
      SETB
             MOV A, #00H ; No limit loop
      LOOP
      VOM
             A,#01H
      BRA
             LOOP
;-----Interrupt program------
WARI:
      CLRB
             I:DIRR RO ;Clear interrupt request flag
      User processing
;
        :
      RETI
                          ; Recovery from interrput
      ENDS
CODE
;------Vector setting------
VECT
      CSEG
             ABS=0FFH
      ORG
                         ;Setting vector to interrupt #42 (2AH)
             OFF54H
      DSL
             WARI
      ORG
             OFFDCH
                         ;Reset vector setting
      DSL
             START
             00H
                         ;Setting to single-chip mode
      DB
VECT
      ENDS
      END
               START
```

# CHAPTER 5 CLOCKS

This chapter explains the clocks used by MB90360 series microcontrollers.

- 5.1 Clocks
- 5.2 Block Diagram of the Clock Generation Block
- 5.3 Clock Selection Register (CKSCR)
- 5.4 PLL/Subclock Control Register (PSCCR)
- 5.5 Clock Mode
- 5.6 Oscillation Stabilization Wait Interval
- 5.7 Connection of an Oscillator or an External Clock to the Microcontroller

## 5.1 Clocks

The clock generation block controls the operation of the internal clock that controls operation of the CPU and peripheral functions. The clock generated by the clock generation block is called the machine clock. One cycle of machine clock is called one machine cycle. The clock to be supplied from a high-speed oscillator is called an oscillation clock, and the 2-frequency division of the oscillation clock is called a main clock. The 4- or 2-frequency division of the clock supplied from a low-speed oscillator or internal CR oscillation clock is called a sub-clock, and the clock by the PLL oscillation is called PLL clock.

#### ■ Clocks

The clock generation block contains the oscillation circuit that generates the oscillation clock by connecting oscillator to oscillation pin. External clock inputted to the oscillation pins can be used as oscillation clock. The clock generation block also contains the PLL clock multiplier circuit, which generates five clocks whose frequencies are multiplication of the oscillation clock frequency. The clock generation block controls the oscillation stabilization wait interval and PLL clock multiplication as well as internal clock operation by changing the clock with a clock selector.

### Oscillation clock (HCLK)

The oscillation clock is generated either by connecting the oscillator to high-speed oscillator pins (X0,X1) or by the input of an external clock.

#### Main clock (MCLK)

The main clock, whose frequency is the oscillation clock frequency divided by 2, supplies the clock input to the timebase timer and the clock selector.

#### Sub-clock (SCLK)

The sub-clock is a clock by connecting the oscillator to the low-speed oscillation pins (X0A, X1A) or by inputting the external clock or the internal CR oscillation clock divided by 4 or 2. The division ratio of sub-clock is determined by SCDS bit of PLL/Subclock Control Register (PSCCR). The sub-clock can be used as operation clock of the watch timer or the low-speed machine clock.

#### PLL clock (PCLK)

The PLL clock is obtained by multiplying the oscillation clock frequency with the PLL clock multiplier circuit (PLL oscillation circuit). One of five types of clocks can be selected by setting the multiplication ratio selection bits (CKSCR: CS1, CS0, PSCCR: CS2)

#### Machine clock

The machine clock controls the operation of the CPU and peripheral functions. One cycle of machine clock is regarded as one machine cycle  $(1/\phi)$ . An operating machine clock can be selected from among the main clock, sub-clock, and five types of PLL clock.

#### Note:

When the operating voltage is 5 V, the oscillation clock can be between 3 MHz and 16 MHz. When an external clock source is used, its frequency can be between 3 MHz and 24 MHz. The highest operating frequency for the CPU and peripheral resource is 24 MHz. However, normal operation is not guaranteed if a multiplication ratio resulting in a higher frequency than 24 MHz is specified.

Therefore, when 24 MHz external clock is inputted, 1 can be specified for the PLL clock multiplication ratio. The PLL oscillation operates at the range of 4 MHz to 24 MHz, but the PLL oscillation range differs by operation voltage and multiplication ratio. See the data sheet for the details.

#### **■** Clock Supply Map

Since the machine clock generated in the clock generation block is supplied as the clock that controls the operation of the CPU and peripheral functions, the operation of the CPU and the peripheral functions is affected by switching between the main clock, the PLL clock and the subclock (clock mode) and by a change in the PLL clock multiplication ratio. Since some peripheral functions receive frequency-divided output from the timebase timer, a peripheral unit can select the clock best suited for this operation. Figure 5.1-1 shows the clock supply map.



Figure 5.1-1 Clock Supply Map

# 5.2 Block Diagram of the Clock Generation Block

The clock generation block consists of five blocks:

- System clock generation circuit/sub-clock generation circuit
- PLL multiplier circuit
- Clock selector
- Clock selection register (CKSCR)
- PLL/sub-clock control register (PSCCR)
- Oscillation stabilization wait interval selector

#### ■ Block Diagram of the Clock Generation Block

Figure 5.2-1 shows a block diagram of the clock generation block. The figure also includes the standby control circuit and timebase timer circuit.



Figure 5.2-1 Block Diagram of the Clock Generation Block

#### Oscillation clock generation circuit

This circuit generates an oscillation clock (HCLK) by connecting an oscillator or inputting an external clock to the high-speed oscillation pins.

#### Sub-clock generation circuit

This circuit generates a sub clock (SCLK) by connecting an oscillator or inputting an external clock to the low-speed oscillation pins (X0A, X1A).

#### PLL multiplier circuit

This circuit multiplies the oscillation clock and supplies it as a PLL clock (PCLK) to the clock selector.

#### Clock selector

From among the main clock, five different PLL clocks and subclock, the clock selector selects the clock that is supplied to the CPU and peripheral function.

#### Clock selection register (CKSCR)

The clock selection register is used to switch between the oscillation clock and PLL clock and between the main clock and sub-clock, also used to select an oscillation stabilization wait interval and a PLL clock multiplier.

#### PLL/Subclock Control Register (PSCCR)

The PLL/subclock control register is used to select multiplication ratio of the PLL (CS2 bit in this register in addition to CS1 and CS0 bits in the CKSCR register) and to specify division ratio (1/4 or 1/2) of the subclock.

#### Oscillation stabilization wait interval selector

This oscillation stabilization wait interval selector selects an oscillation stabilization wait interval for the oscillation clock. Selection is made from among four different timebase timer outputs.

# 5.2.1 Register of Clock Generation Block

This section explains the register of the clock generation block.

## ■ Clock Selection Register and List of Reset Value

Figure 5.2-2 Clock Selection Register and List of Reset Value



# 5.3 Clock Selection Register (CKSCR)

The clock selection register (CKSCR) is used to switch among the main clock, PLL clocks and subclock, also used to select an oscillation stabilization wait interval and a PLL clock multiplier.

#### ■ Configuration of the Clock Selection Register (CKSCR)

Figure 5.3-1 Configuration of the Clock Selection Register (CKSCR)



Table 5.3-1 Functions of Clock Selection Register (CKSCR) (1/2)

| Bit name       |                                                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |
|----------------|--------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit15          | SCM:<br>Sub clock operation<br>flag bit                            | The bit indicates the main clock or subclock currently selected as the machine clock. When the sub clock operation flag bit (CKSCR: SCM) is "0" and the sub clock select bit (CKSCR: SCS) is "1", it indicates that the machine clock is currently switching from subclock to main clock. When the sub clock operation flag bit (CKSCR: SCM) is "1" and the sub clock select bit (CKSCR: SCS) is "0", it indicates that the machine clock is currently switching from main clock to subclock. (The writing operation will not be affected.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| bit14          | MCM:<br>PLL clock operation<br>flag bit                            | The bit indicates the main clock or PLL clock currently selected as the machine clock. When the PLL clock operation flag bit (CKSCR: MCM) is "1" and the PLL clock select bit (CKSCR: MCS) is "0", it indicates that the oscillation stabilization wait time of the PLL clock is currently being taken. (The writing operation will not be affected.)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |  |
| bit13<br>bit12 | WS1, WS0:<br>Oscillation<br>stabilization wait<br>time select bits | These bits are used to select an oscillation stabilization wait time required for the oscillation clock when the stop mode is canceled, when transition occurs from subclock mode to main clock mode, or when transition occurs from subclock mode to PLL clock mode.  These bits are used to select one from four timebase timer outputs.  Any reset causes the bit to return to the reset value.  Note: Set the oscillation stabilization wait time to an appropriate value depending on the oscillator used. See 7.2.1 Reset Factors and Oscillation Stabilization Wait Times.  The oscillation stabilization wait time taken when the clock mode is switched from main clock to PLL clock is fixed at 2 <sup>14</sup> /HCLK (about 4.1 ms during operation at an oscillation clock frequency of 4 MHz). When the CPU switches from subclock mode to PLL clock mode or when it returns from PLL stop mode to PLL clock mode, the oscillation stabilization wait time follows the values specified in these bits.  The PLL clock requires an oscillation stabilization wait time of at least 2 <sup>14</sup> /HCLK. For switching from subclock mode to PLL clock mode and transiting to the PLL stop mode, therefore, set these bits to "10 <sub>B</sub> " or "11 <sub>B</sub> ".                                                                                                                                                                                                                                                                                                                     |  |  |  |
| bit11          | SCS:<br>Sub clock select bit                                       | This bit indicates the main clock or sub clock to be selected as the machine clock.  When the machine clock is switched from the main clock to the subclock (CKSCR: SCS = 1 → 0), the main clock mode changes to the subclock mode of 1/SCLK (32.768 kHz oscillation clock frequency, operating at 4 division: approx. 130 μs) in synchronization with the subclock.  When the machine clock is switched from the subclock to the main clock (CKSCR: SCS = 0 → 1), the clock mode changes from subclock mode to main clock mode after the main clock oscillation stabilization wait time is generated. Timebase timer is cleared automatically. Any reset causes the bit to return to the reset value.  Notes:  1) When both of the MCS and SCS bits contain 0, the SCS bit supersedes the MCS bit, thereby setting the subclock mode.  2) If both the subclock select bit (CKSCR: SCS) and PLL clock select bit (CKSCR: MCS) contain 0, the sub clock is preferred.  3) When switching from the main clock to subclock (CKSCR: SCS = 1 → 0), use the timebase timer interrupt enable bit (TBTC: TBIE) or interrupt level mask register (ILM: ILM2 to 0) to disable timebase timer interrupts before writing 0 to the subclock select bit.  4) The 2 <sup>14</sup> /SCLK sub clock oscillation stabilization wait time (32.768 kHz oscillation clock frequency, operating at 4 division: approx. 2 s) is generated at power on or at cancellation of the stop mode.If the clock mode is switched from main clock mode to subclock mode, therefore, the oscillation stabilization wait time is generated. |  |  |  |

Table 5.3-1 Functions of Clock Selection Register (CKSCR) (2/2)

| Bit name     |                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   |                               |  |
|--------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|-------------------------------|--|
| bit10        | MCS:<br>PLL clock select bit                    | This bit indicates the main clock or PLL clock to be selected as the machine clock.                                                                                                                                                                                                                                                                                                                                    |   |   |   |                               |  |
| bit9<br>bit8 | CS1, CS0:<br>Multiplication rate<br>select bits | These bits select the PLL clock multiplication rate with the CS2 bit in the PLL/subclock control register (PSCCR).  One of five types of PLL clock multiplication rate can be selected.  Any reset causes the bit to return to the reset value.  Setting of CS0, CS1, and CS2                                                                                                                                          |   |   |   |                               |  |
|              |                                                 | CS2 CS1 CS0 PLL clock multiplication rate                                                                                                                                                                                                                                                                                                                                                                              |   |   |   | PLL clock multiplication rate |  |
|              |                                                 | 0 0 0 ×1                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   | × 1                           |  |
|              |                                                 | 0 0 1 ×2                                                                                                                                                                                                                                                                                                                                                                                                               |   |   |   | × 2                           |  |
|              |                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 1 | 0 | × 3                           |  |
|              |                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                        | 0 | 1 | 1 | × 4                           |  |
|              |                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                        | 1 | 1 | 0 | ×6                            |  |
|              |                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                        | 1 | 1 | 1 | Setting disabled              |  |
|              |                                                 | Note: Setting CS2 to CS0 bits to " $111_B$ " is prohibited. When PSCCR: CS2 is set to " $1$ ", do not set CKSCR: CS1 and CS0 to " $11_B$ ". When the PLL clock is selected (CKSCR: MCS = 0), writing is inhibited. To change the multiplier, write 1 to the PLL clock select bit (CKSCR: MCS), update the multiplication rate select bits (CKSCR: CS1, CS0), then set the PLL clock select bit (CKSCR: MCS) back to 0. |   |   |   |                               |  |

# 5.4 PLL/Subclock Control Register (PSCCR)

PLL/Subclock control register selects the PLL multiplication rate and subclock division rate. This register is write only. Read value of all bits is set to "1".

#### ■ Configuration of the PLL/Subclock Control Register (PSCCR)

Figure 5.4-1 shows the configuration of the PLL/Subclock control register (PSCCR). Table 5.4-1 shows the function of each bit in the PLL/subclock control register (PSCCR).

Address 15 14 12 11 10 9 8 Reset value 13 SCDS 0000CF<sub>H</sub> CS2 XXXX0000<sub>B</sub> Re-served W W W bit8 CS2 Multiplication rate selection bit 0 See the clock selection register (CKSCR). 1 bit9 Reserved Reserved bit Always write "0" to this bit. Read value is always "1". bit10 SCDS Subclock division selection bit W : Write only 4 division : Undefined Χ 2 division : Unused : Initial value bit11 Reserved bit Always write "0" to this bit. Read value is always "1".

Figure 5.4-1 Configuration of the PLL/Subclock Control Register (PSCCR)

Table 5.4-1 Functional Description of Each Bit in the PLL/subclock Control Register (PSCCR)

| Bit name             |                                                | Function                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                     |     |     |                               |   |
|----------------------|------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----|-------------------------------|---|
| bit15<br>to<br>bit12 | Unused                                         | Writin                                                                                                                                                                                                                                                        | These bits are not used. Writing to these bits has no effect to operation. Read value is always "1".                                                                                                                                                |     |     |                               |   |
| bit11                | Reserved bit                                   |                                                                                                                                                                                                                                                               | Always write "0" to this bit. Read value is always "1".                                                                                                                                                                                             |     |     |                               |   |
| bit10                | SCDS:<br>Subclock<br>division selection<br>bit | When<br>When<br>Read                                                                                                                                                                                                                                          | The division ratio of the subclock is selected.  When "0" is written to this bit, 4 division is selected.  When "1" is written to this bit, 2 division is selected.  Read value is always "1".  This bit is initialized to "0" by all reset causes. |     |     |                               |   |
| bit9                 | Reserved bit                                   | Always write "0" to this bit. Read value is always "1".                                                                                                                                                                                                       |                                                                                                                                                                                                                                                     |     |     |                               |   |
| bit8                 | CS2:<br>Multiplication<br>rate selection bit   | This bit and CS1 and CS0 bits of the clock selection register (CKSCR) determine the PLL multiplication rate.                                                                                                                                                  |                                                                                                                                                                                                                                                     |     |     |                               |   |
|                      |                                                |                                                                                                                                                                                                                                                               | CS2                                                                                                                                                                                                                                                 | CS1 | CS0 | PLL clock multiplication rate |   |
|                      |                                                |                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                   | 0   | 0   | ×1                            | 1 |
|                      |                                                |                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                   | 0   | 1   | × 2                           | 1 |
|                      |                                                |                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                   | 1   | 0   | ×3                            | 1 |
|                      |                                                |                                                                                                                                                                                                                                                               | 0                                                                                                                                                                                                                                                   | 1   | 1   | × 4                           |   |
|                      |                                                |                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                   | 1   | 0   | × 6                           |   |
|                      |                                                |                                                                                                                                                                                                                                                               | 1                                                                                                                                                                                                                                                   | 1   | 1   | Setting disabled              | ] |
|                      |                                                | Read value is always "1".  This bit is initialized to "0" by all reset causes.  Note: When MCS or MCM bit is "0", setting CS2 to CS0 to "111 <sub>B</sub> " is prohibited.  When CKSCR: CS1 and CS0 is set to "11 <sub>B</sub> ", do not set "1" to this bit. |                                                                                                                                                                                                                                                     |     |     |                               |   |

Note: PSCCR register is write-only register. Read value is different from writing value. Do not use the RMW instruction (SETB/CLRB instruction).

#### 5.5 Clock Mode

# Three clock modes are provided: main clock mode, PLL clock mode and sub-clock mode.

#### ■ Clock Mode

#### Main clock mode

In main clock mode, a clock with 2-frequency division of the clock generated by connecting on oscillator or by inputting from external to the high-speed oscillation pins (X0, X1) is used.

#### Sub-clock mode

In sub-clock mode, a clock with 4/2-frequency division of the clock generated by connecting an oscillator or inputting from external, or the internal CR oscillation clock to the low-speed oscillation pins (X0A, X1A) is used.

The subclock division ratio is determined by SCDS bit of PLL/subclock control register (PSCCR).

#### PLL clock mode

In PLL clock mode, a PLL clock is used as the operating clock for the CPU and peripheral resources. A PLL clock multiplier is selected with the clock selection register (CKSCR: CS1 and CS0) and PLL/subclock control register (PSCCR: CS2).

#### **■** Clock Mode Transition

Transition among main clock mode, PLL clock mode, and sub-clock mode is performed by writing to the MCS and SCS bits of the clock selection register (CKSCR).

#### Transition from main clock mode to PLL clock mode

When the MCS bit of the clock selection register (CKSCR) is rewritten from "1" to "0" in main clock mode, switching from the main clock to a PLL clock occurs after the PLL clock oscillation stabilization wait interval (2<sup>14</sup>/HCLK).

#### Transition from PLL clock mode to main clock mode

When the MCS bit of the clock selection register (CKSCR) is rewritten from "0" to "1" in PLL clock mode, switching from the PLL clock to the main clock occurs when the edges of the PLL clock and the main clock coincide (after 1 to 12 PLL clocks).

#### Transition from main clock mode to sub-clock mode

When the SCS bit of the clock selection register (CKSCR) is rewritten from "1" to "0" in main clock mode, switching from the main clock to a sub-clock occurs by synchronizing with the subclock.

#### Transition from sub-clock mode to main clock mode

When the SCS bit of the clock selection register (CKSCR) is rewritten from "0" to "1" in sub-clock mode, switching from the sub-clock to the main clock occurs after the main clock oscillation stabilization wait interval.

#### Transition from PLL clock mode to sub-clock mode

When the SCS bit of the clock selection register (CKSCR) is rewritten from "1" to "0" in PLL clock mode, switching from the PLL clock to the sub-clock occurs.

#### Transition from sub-clock mode to PLL clock mode

When the SCS bit of the clock selection register (CKSCR) is rewritten from "0" to "1" in sub-clock mode, switching from the sub-clock to a PLL clock occurs after the main clock oscillation stabilization wait interval.

#### ■ Selection of a PLL Clock Multiplier

Writing the value from " $000_B$ " to " $011_B$ " and " $110_B$ " to the CS1 and CS0 bits of the clock selection register (CKSCR) and CS2 bit of the PLL/subclock control register (PSCCR) can select five types (1 to 4 multiplication and 6 multiplication) of PLL clock multiplier.

#### ■ Machine Clock

PLL clock, main clock, and sub-clock outputted from the PLL multiplier circuit are used as machine clock. This machine clock is supplied to the CPU and peripheral functions. The main clock, PLL clock, or sub-clock can be selected by writing to the MCS or SCS bit of the clock selection register (CKSCR).

#### **Notes:**

Even though the MCS and SCS bits of the clock selection register (CKSCR) are rewritten, machine clock switching does not occur immediately. When operating a resource that depends on the machine clock, confirm that machine clock switching has been performed by referring to the MCM and SCM bits of the clock selection register (CKSCR) before operating the resource.

When the MCS bit of the clock selection register (CKSCR) is "0" (PLL clock mode) and when the SCS bit of the clock selection register (CKSCR) is "0" (sub-clock mode), the SCS bit is prioritized, and a transition to the sub-clock mode is occurred.

When the clock mode is switched, do not switch to other clock mode and low-power consumption mode before this switching is completed. Confirm the completion of clock mode switching by referring to the MCM and SCM bits of the clock selection register (CKSCR).

If switching to other clock mode and low-power consumption mode is performed before a transition is completed, the mode may not be switched.

Main --> Sub MCS = 1MCM = 1Sub SCS = 0Main (10)(11) MCS = XMCS = 1(12) SCM = 1MCM = 1CS1, CS0 =  $xx_B$ MCM = 1SCS = 0CS2=x SCS = 1(1) SCM = 0(20) SCM = 1CS1, CS0 =  $xx_B$ CS1, CS0 =  $xx_B$ (12)(13)Sub --> Main CS2=x CS2=x(11) MCS = 1 **A A A** MCM = 1SCS = 1 (10) (8) SCM = 0Sub --> PLL Main --> PLLx (2) CS1, CS0 =  $xx_B$ MCS = 0MCS = 0(3) CS2=x MCM = 1 MCM = 1(16) (4) SCS = 1 SCS = 1(17) (5) SCM = 0SCM = 1(18) (6) CS1, CS0 = xx<sub>E</sub> CS1, CS0 =  $xx_B$ CS2=0 CS2=x PLL1: Multiplied PLL1 --> Main PLL1 --> Sub (21) MCS = 0MCS = 1 MCS = 1(9) MCM = 0MCM = 0MCM = 0SCS = 1SCS = 0 SCS = 1SCM = 1SCM = 1 SCM = 1(8) CS1, CS0 =  $00_B$ (10) CS1, CS0 = 00<sub>B</sub> ◀ CS1, CS = 00<sub>B</sub> CS2=0 CS2=0 CS2=0 PLL2 --> Sub PLL2 --> Main (21) PLL2: Multiplied (9) MCS = 1MCS = 0MCS = 1MCM = 0MCM = 0MCM = 0SCS = 0SCS = 1SCS = 1 SCM = 1SCM = 1SCM = 1 (8)(10)CS1, CS0 = 01<sub>B</sub> CS1, CS0 =  $01_{R}$ CS1, CS0 = 01<sub>B</sub> CS2=0 CS2=0 CS2=0 PLL3 --> Main PLL3 --> Sub (21) PLL3: Multiplied MCS = 1MCS = 1(9) MCS = 0MCM = 0MCM = 0MCM = 0SCS = 1SCS = 0SCS = 1SCM = 1SCM = 1SCM = 1(10) CS1, CS0 =10<sub>B</sub> CS1, CS0 =  $10_B$ CS1, CS0 =  $10_B$ CS2=0 CS2=0 CS2=0 PLL4 --> Main PLL4 --> Sub (21)PLL4: Multiplied MCS = 1 MCS = 1 MCS = 0 (9) MCM = 0MCM = 0MCM = 0SCS = 1 SCS = 0SCS = 1 SCM= 1 SCM = 1 (8) (10)CS1, CS0 = 11<sub>B</sub> ◀ CS1, CS0 = 11<sub>B</sub> CS1, CS0 = 11<sub>B</sub> CS2=0 CS2=0 PLL6 --> Sub (21) PLL6 --> Main PLL6: Multiplied MCS = 1MCS = 1(9) MCS = 0MCM = 0MCM = 0MCM = 0SCS = 0SCS = 1SCS = 1SCM = 1 SCM = 1(8) SCM = 1(10)CS1, CS0 = 10<sub>B</sub> CS1, CS0 =10<sub>B</sub> CS1, CS0 = 10<sub>B</sub> CS2=1 CS2=1 CS2=1

Figure 5.5-1 shows the status change caused by machine clock switching.

Figure 5.5-1 Status Change Diagram for Machine Clock Selection

| (1)      |   | Write "0" to MCS bit                                                                              |
|----------|---|---------------------------------------------------------------------------------------------------|
| (2)      |   | Termination of PLL clock oscillation stabilization wait time & CS1, CS0= $00_B$ & CS2= $0$        |
| (3)      |   | Termination of PLL clock oscillation stabilization wait time & CS1, CS0= 01 <sub>B</sub> & CS2= 0 |
| (4)      |   | Termination of PLL clock oscillation stabilization wait time & CS1, CS0= 10 <sub>B</sub> & CS2= 0 |
| (5)      |   | Termination of PLL clock oscillation stabilization wait time & CS1, CS0= 11 <sub>B</sub> & CS2= 0 |
| (6)      |   | Termination of PLL clock oscillation stabilization wait time & CS1, CS0= $10_B$ & CS2= $1$        |
| (7)      |   | Write "1" to MCS bit (include reset)                                                              |
| (8)      |   | Synchronous timing of PLL clock and main clock                                                    |
| (9)      |   | Write "0" to SCS bit                                                                              |
| (10)     |   | Synchronous timing of main clock and sub-clock                                                    |
| (11)     |   | Write "1" to SCS bit (MCS1)                                                                       |
| (12)     |   | Termination of main clock oscillation stabilization wait time                                     |
| (13)     |   | Termination of main clock oscillation stabilization wait time & CS1, CS0= $00_B$ & CS2= $0$       |
| (14)     |   | Termination of main clock oscillation stabilization wait time & CS1, CS0= $01_B$ & CS2= $0$       |
| (15)     |   | Termination of main clock oscillation stabilization wait time & CS1, CS0= $10_{\rm B}$ & CS2= $0$ |
| (16)     |   | Termination of main clock oscillation stabilization wait time & CS1, CS0= $11_B$ & CS2= $0$       |
| (17)     |   | Termination of main clock oscillation stabilization wait time & CS1, CS0= $10_{\rm B}$ & CS2= $1$ |
| (18)     |   | Write "1" to SCS bit (MCS0)                                                                       |
| (19)     |   | Synchronous timing of PLL clock and sub-clock                                                     |
|          |   |                                                                                                   |
| MCS      | : | Machine clock select bit of clock selection register (CKSCR)                                      |
| MCM      | : | Machine clock display bit of clock selection register (CKSCR)                                     |
| SCS      | : | Machine clock display bit (sub) of clock selection register (CKSCR)                               |
| SCM      | : | Machine clock select bit (sub) of clock selection register (CKSCR)                                |
| CS1, CS0 | : | Machine clock of clock selection register (CKSCR)                                                 |
| CS2      | : | Multiplication rate selection bit of PLL/ subclock control register (PSCCR)                       |

#### **Notes:**

- The initial value for the machine clock setting is main clock (CKSCR: MCS = 1, SCS = 1).
- If both the SCS and MCS bits are "0", the SCS bit takes precedence, that is, the sub-clock is selected.
- When sub-clock mode is switched to PLL clock mode, set the WS1 and WS0 bits of CKSCR to " $10_B$ " or " $11_B$ ."

#### 5.6 Oscillation Stabilization Wait Interval

When the power is turned on during the oscillation clock is stopped or when stop mode is released, a time until the oscillation clock stabilizes (oscillation stabilization wait time is required immediately after oscillation starts. Also, the oscillation stabilization wait time is required when the clock mode is switched from main clock to PLL clock, main clock to sub-clock, sub-clock to main clock, and sub-clock to PLL clock.

#### ■ Oscillation Stabilization Wait Interval

Ceramic and crystal oscillators generally require several to dozens of ms to stabilize at their natural frequency (oscillation frequency) when oscillation starts. For this reason, CPU operation is not allowed immediately after oscillation starts but is allowed only after full oscillation stabilization. After the oscillation stabilization wait interval has elapsed, the machine clock is supplied to the CPU. Because the oscillation stabilization wait time depends on the type of oscillator (crystal, ceramic, etc.), the proper oscillation stabilization wait interval for the oscillator used must be selected. An oscillation stabilization wait interval is selected by setting the clock selection register (CKSCR).

When clock mode is switched from main clock to PLL clock, main clock to subclock, subclock to main clock, or subclock to PLL clock, the CPU runs in the clock mode set before switching for the oscillation stabilization wait time. After the oscillation stabilization wait time has elapsed, the CPU changes to the specified clock mode.

Figure 5.6-1 shows the operation immediately after oscillation starts.



Figure 5.6-1 Operation Immediately after Oscillation Stabilization Wait Time

# 5.7 Connection of an Oscillator or an External Clock to the Microcontroller

The MB90360 series microcontroller contains a system clock generation circuit. Connecting an external oscillator to this circuit generates the system clock. Alternatively, an externally generated clock can be input to the microcontroller.

#### ■ Connection of an Oscillator or an External Clock to the Microcontroller

Example of connecting a crystal or ceramic oscillator to the microcontroller

Figure 5.7-1 Example of Connecting a Crystal or Ceramic Oscillator to the Microcontroller



Example of connecting an external clock to the microcontroller

Figure 5.7-2 Example of Connecting an External Clock to the Microcontroller



# **CHAPTER 6**

# **CLOCK SUPERVISOR**

This chapter explains the function and the operation of the clock supervisor. Only the product with built-in clock supervisor of the MB90360 series is valid to this function.

- 6.1 Overview of Clock Supervisor
- 6.2 Block Diagram of Clock Supervisor
- 6.3 Clock Supervisor Control Register (CSVCR)
- 6.4 Operating Mode of Clock Supervisor

# 6.1 Overview of Clock Supervisor

The clock supervisor checks the oscillation of the main clock or a sub-clock (without "S" suffix product). When the main clock or a sub-clock stops due to some breakdowns, the control circuit of the clock supervisor switches the clock source to built-in CR oscillation clock, sets the detection flag, and generates reset.

#### ■ Overview of Clock Supervisor

The clock supervisor checks the oscillation of the main clock or the sub-clock. If the using (main or sub) clock stops during the fixed time (20  $\mu$ s to 80  $\mu$ s: When the main clock is used, 160  $\mu$ s to 640  $\mu$ s: When the sub clock is used), the corresponding clock stop detection flag is set and reset is generated after switching the stopped clock to the CR oscillation clock.

The reset factor can be checked by the reset factor bit of watchdog timer control register (WDTC).

Supervising a main and a sub-clock can be set to the disable (watching prohibition) respectively independently.

When a sub-clock stops while the device is operating in the main clock mode, internal reset is not generated at once. When changing to the sub-clock mode, internal reset is generated. It is also possible to control the internal reset generation by the setting in this case.

When the device changes to the stop mode, the main-/sub-clock supervisor is automatically disabled (watching prohibition). Either of main or sub clock supervisor that is the condition that was enable before the stop mode changed automatically returns from disabled to enabled when returning from the stop mode.

Built-in CR oscillation clock can be used as a sub-clock of the device if the product is the external single-clock product (with "S" suffix product).

#### Note:

At power-on, the clock supervisor starts monitoring immediately after a lapse of the oscillation stability waiting time for the main clock.

# 6.2 Block Diagram of Clock Supervisor

The clock Supervisor is composed of the following block:

- Main clock supervisor
- Sub clock supervisor
- Control circuit
- Clock supervisor control register (CSVCR)
- · Main clock selector
- · Sub clock selector
- CR oscillation circuit

#### ■ Block Diagram of Clock Supervisor

Figure 6.2-1 shows the block diagram of clock supervisor.



#### Main clock supervisor

The oscillation of the main oscillation clock (HCLK) is supervised by using the clock from the CR oscillation circuit as a clock source.

#### Sub clock supervisor

The oscillation of the sub oscillation clock (SCLK) is supervised by using the clock from the CR oscillation circuit as a clock source.

#### Control circuit

Disable or enable for main/sub clock supervisor, existence of internal reset generation when clock halt condition is detected, and switching to CR oscillation clock of clock to be monitored are controlled by setting of clock supervisor control register (CKSCR).

#### Clock supervisor control register (CKSCR)

Disable or enable for main/sub clock supervisor, existence of internal reset generation when clock halt condition is detected, or switching to CR oscillation clock of clock to be monitored are selected.

#### Main clock selector

CR oscillation clock is outputted as main clock when the main oscillation clock is missing.

#### Sub clock selector

The divided clock of CR oscillation clock is outputted as sub clock when the sub oscillation clock is missing.

#### CR oscillation circuit

Internal CR oscillation clock circuit. Disable/enable the CR oscillation can be selected by the control circuit.

# 6.3 Clock Supervisor Control Register (CSVCR)

This register switches main clock/sub clock/PLL clock, and selects the oscillation stabilization wait time and PLL clock multiplication rate.

#### ■ Clock Supervisor Control Register (CSVCR)

Figure 6.3-1 Clock Supervisor Control Register (CSVCR)



|      | Bit name                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7 | SCKS<br>Sub clock select                   | This bit permits built-in CR oscillation clock to be used as a sub-clock. Only "S" suffix product is valid to this function.  "1": It is possible to change to the sub clock mode with built-in CR oscillation clock.  "0": It is not possible to change to the sub clock mode.  This bit is initialized to "0" by power-on reset, external reset, or low voltage detection reset in "T" suffix product. It is initialized to "0" by power-on reset or external reset without "T" suffix product.  It is necessary to set this bit to "1" in the main clock mode before the sub-clock supervisor after the above-mentioned is initialized operates automatically.  Moreover, after setting to "1", this bit cannot be reset to "0" by software. |
| bit6 | MM<br>Main clock<br>missing                | This bit indicates the oscillation missing of main clock terminal X0 and X1 was detected.  "1": Missing main clock has been detected.  "0": Missing main clock has not been detected.  This bit is initialized to "0" by power-on reset, external reset, or low voltage detection reset with "T" suffix product.  It is initialized to "0" by power-on reset or external reset without "T" suffix product.                                                                                                                                                                                                                                                                                                                                      |
| bit5 | SM<br>Sub clock<br>missing                 | This bit indicates the oscillation missing of sub clock terminal X0A and X1A was detected. No "S" suffix product is valid to this function.  "1": Missing sub-clock has been detected.  "0": Missing sub-clock has not been detected.  This bit is initialized to "0" by power-on reset, external reset, or low voltage detection reset with "T" suffix product.  It is initialized to "0" by power-on reset or external reset without "T" suffix product.                                                                                                                                                                                                                                                                                      |
| bit4 | RCE<br>CR oscillation<br>clock enable      | This bit permits built-in CR oscillation.  "1": Built-in CR oscillation is enabled.  "0": Built-in CR oscillation is disabled.  This bit is initialized to "1" by power-on reset, external reset, or low voltage detection reset with "T" suffix product.  It is initialized to "1" by power-on reset or external reset without "T" suffix product.  Please set this bit in "1" after confirming both the following:  - The supervisor of main and sub-clock is disabled.  - MM and SM bits are "0".                                                                                                                                                                                                                                            |
| bit3 | MSVE<br>Main clock<br>supervisor<br>enable | This bit permits monitoring for main clock oscillation.  "1": Main clock supervisor is enabled.  "0": Main clock supervisor is disabled.  This bit is initialized to "1" by power-on reset or low voltage detection reset with "T" suffix product.  It is initialized to "1" by power-on reset or external reset without "T" suffix product.                                                                                                                                                                                                                                                                                                                                                                                                    |
| bit2 | SSVE<br>Sub clock<br>supervisor<br>enable  | This bit permits monitoring for sub clock oscillation.  "1": Sub clock supervisor is enabled.  "0": Sub clock supervisor is disabled.  This bit is initialized to "1" by power-on reset or low voltage detection reset with "T" suffix product.  It is initialized to "1" by power-on reset or external reset without "T" suffix product.                                                                                                                                                                                                                                                                                                                                                                                                       |
| bit1 | SRST<br>Sub-clock mode<br>reset            | This bit permits the reset output when transmitting from main clock/PLL clock mode to the sub-mode with sub-clock breakdown.  "1": Output reset.  "0": Not output reset  This bit is initialized to "0" by power-on reset, external reset, or low voltage detection reset with "T" suffix product.  It is initialized to "0" by power-on reset or external reset without "T" suffix product.                                                                                                                                                                                                                                                                                                                                                    |
| bit0 | Reserved bit                               | This bit is reserved. Be sure to write "0" to this bit. Read value is always "0".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# 6.4 Operating Mode of Clock Supervisor

This section explains all the operating modes of the Clock Supervisor.

#### ■ Operating Mode in Initialized State

The CR oscillation circuit, the main clock supervisor and the sub-clock supervisor are enabled before the clock supervisor control register (CSVCR) is set by the user program.

- After power-on reset or reset of the low voltage detection, the CR oscillation circuit is enabled with "T" suffix product. After power-on reset or external reset, the CR oscillation circuit is enabled without "T" suffix product.
- If the main clock goes off after a lapse of the oscillation stability waiting time (2<sup>11</sup>/HCLK), the main clock monitor function will be immediately enabled to cause reset to occur.
- If the main clock goes off before a lapse of the oscillation stability waiting time after power-on reset, the main clock monitor function will cause reset after a lapse of the 2<sup>12</sup> cycle of CR oscillation clock (approximately 41 ms for the CR oscillation of 100 kHz).
- If the main clock goes off during the period of power-on reset, the device will retain the reset state.
- After it passes of 2<sup>18</sup> cycles of the CR oscillation clock (For about 2.6 s:CR oscillation 100 kHz), the sub-clock supervisor is valid.
- When the main clock is stopped on the main clock supervisor enable state, the main clock is replaced with the CR oscillation clock, MM bit is set to one, and the reset is generated.
- When the sub clock is stopped on the sub clock mode, the sub clock is replaced with the CR oscillation two dividing frequency clock, SM bit is set to one, and the reset is generated. When the sub clock is stopped on the main clock mode, the sub clock is replaced with the CR oscillation two dividing frequency clock, SM bit is set to one. However, the reset is not generated at the sub-clock mode transition because the initial value of SRST bit is "0".

#### ■ Prohibition Setting of CR Oscillation Circuit and Clock Supervisor

In the following settings, it is assumptions that the CR oscillation circuit, the main clock supervisor, and the sub-clock supervisor are operating.

- MSVE(CSVCR:bit3) is set to 0 and the main clock supervisor is set disable.
- SSVE(CSVCR:bit2) is set to 0 and the sub clock supervisor is set disable.
- The RCE bit (bit4 of CSVCR) is set to 0 and the CR oscillation circuit is set disable. Please set it after checking that the main clock and the sub-clock supervisor are disabled, and both SM and MM (bit4 of CSVCR) are 0. Do not set RCE to 0 when either SM or MM is one.

#### ■ Reoperating Setting of CR Oscillation Circuit and Clock Supervisor

In the following settings, it is assumptions that the CR oscillation circuit, the main clock supervisor, and the sub-clock supervisor are stopped.

- RCE(CSVCR:bit4) is set to 1 and the CR oscillation circuit is set enable.
- MSVE(CSVCR:bit3) is set to 1 and the main clock supervisor is set enable. Please note the programming of software to do after 10  $\mu$ s or more has passed since the CR oscillation circuit was set enable.

• The sub-clock supervisor is operated by setting SSVE(CSVCR:bit2) to 1. Please note the programming of software to do after 10 µs or more has passed since the CR oscillation circuit was set enable.

#### ■ Sub-clock Mode

The main clock supervisor automatically becomes disable at the sub-clock mode. The content of enable bit MSVE never changes. If the main clock was lost after oscillation stability waiting time of  $2^{11}$ /HCLK (about 0.51 ms: at external 4 MHz) or before the oscillation stability waiting time ends, the main clock supervisor is valid after it passes of  $2^{12}$  cycles of the CR oscillation clock (about 41 ms: at CR oscillation 100 kHz) at transition from main clock mode to sub clock mode.

#### ■ Sub-clock Mode Transition Operating When Sub-clock Has Already Stopped

The behavior that shifts to the sub-clock mode depends on the state of the SRST bit when the stop of the sub-clock is detected by the sub-clock supervisor while the device is operating in the main clock mode.

- When SRST is set to 0 (initial state), the reset is not generated at transition to the sub-clock mode. In this case, the CR oscillation clock is used as a sub-clock at transition to the sub-clock mode.
- When SRST is set to 1, the reset is generated at transition to the sub-clock mode.

#### ■ Stop Mode

CR oscillation circuit, the main clock, and the sub-clock supervisor automatically become disable at transition to the stop mode, when all of these functions are enable. Each enable bit of the clock supervisor control register is not changed. Therefore, after it is released from the stop mode, each enable/disable state of CR oscillation circuit and clock supervisor keep the state before they changes to the stop mode.

- The CR oscillation circuit immediately becomes enable after released from the stop mode.
- If the main clock was lost after oscillation stability waiting time of 2<sup>11</sup>/HCLK (about 0.51 ms: at external 4 MHz) or before the oscillation stability waiting time ends, the main clock supervisor is enabled after it passes of 2<sup>12</sup> cycles of the CR oscillation clock (about 41 ms: at CR oscillation 100 kHz).
- After it passes of 2<sup>18</sup> cycles of the CR oscillation clock (For about 2.6 s:CR oscillation 100 kHz), the sub-clock supervisor is valid.

#### ■ Sub-clock Mode with External Single Clock Product

In the sub-clock mode with external single clock product ("S" suffix product), the CR oscillation clock can be used as a sub-clock.

To use this function, SCKS (bit7 of CSVCR) is set to 1 and SRST is set to 0 (initial value). This function can not be used with the external dual clock products (no "S" suffix product).

#### ■ Reset Check By Clock Supervisor

To check whether reset was executed by the clock supervisor, the WDTC register is read with software and the reset factor is checked. When ERSR (bit4 of WDTC) is set, the factor is a reset from an external terminal or a reset by the clock supervisor (include low voltage detection/CPU operating detection reset in "T" suffix products). If both SM and MM bits (bit5 and bit6 of CSVCR) are 0, the reset factor is an external reset (include low voltage detection/CPU operating detection reset in "T" suffix products). If SM is 1, the reset factor is a sub-clock lost. If MM is 1, the reset factor is a main-clock lost.

#### CHAPTER 6 CLOCK SUPERVISOR

# CHAPTER 7 RESETS

This chapter describes resets for the MB90360-series microcontrollers.

- 7.1 Resets
- 7.2 Reset Cause and Oscillation Stabilization Wait Times
- 7.3 External Reset Pin
- 7.4 Reset Operation
- 7.5 Reset Cause Bits
- 7.6 Status of Pins in a Reset

## 7.1 Resets

If a reset is generated, the CPU immediately stops the current execution process and waits for the reset to be cleared. The CPU then begins processing at the address indicated by the reset vector.

The four causes of a reset are as follows

- Power-on reset
- External reset request via the RST pin
- Software reset request
- · Watchdog timer overflow
- Low voltage detection reset request (product with "T"-suffix)
- CPU operation detection reset request (product with "T"-suffix)
- Clock supervisor reset request (MB90367/T(S))

#### ■ Causes of a Reset

Table 7.1-1 lists the causes of a reset.

Table 7.1-1 Cause of a Reset

| Reset                                                 | Cause                                                                                                          | Machine clock                 | Watchdog<br>timer | Oscillation stabilization wait |
|-------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------------------|-------------------|--------------------------------|
| Power-on                                              | At power on                                                                                                    | Main clock (MCLK)             | Stop              | Yes                            |
| External pin                                          | L level input to RST pin                                                                                       | Main clock (MCLK)             | Stop              | None                           |
| Software                                              | Write "0" to internal reset signal generation bit (RST) of low-power consumption mode control register (LPMCR) | Main clock (MCLK)             | Stop              | None                           |
| Watchdog timer                                        | Watchdog timer overflow                                                                                        | Main clock (MCLK)             | Stop              | None                           |
| Low voltage detection reset (with "T"-suffix)         | When low voltage $(4.0 \text{ V} \pm 0.3 \text{ V})$ is detected                                               | Main clock (MCLK)             | Stop              | None                           |
| CPU operation<br>detection reset<br>(with "T"-suffix) | When CPU operation detection counter overflows                                                                 | Main clock (MCLK)             | Stop              | None                           |
| Clock supervisor reset                                | When failure of main clock/subclock is detected                                                                | Internal CR oscillation clock | Stop              | None                           |

MCLK: Main clock (oscillation clock frequency divided by 2)

#### Power-on reset

A power-on reset is generated when the power is turned on. The oscillation stabilization wait times is fixed to  $2^{16}$  oscillation clock cycles ( $2^{16}$ /HCLK) (approx. 16.38 ms, oscillating at 4 MHz). When the oscillation

stabilization wait time has elapsed, the reset is executed.

#### External reset

An external reset is generated by the L level input to an external reset pin ( $\overline{RST}$  pin). The minimum required period of the L level is at least 500 ns. Reset operation is performed after oscillation stabilization wait time elapses.

#### Note:

If the reset cause is generated during a write operation, the CPU waits for the reset to be cleared after completion of the instruction only for reset requests via the  $\overline{RST}$  pin. Therefore, the normal write operation is completed even though a reset is inputted concurrently. However, note that the following two points.

Note that a reset may prevent the data transfer requested by a string-processing instruction from being completed because the reset is accepted before a specified number of counters are transferred.

At external bus access, if the cycle is exceeded a certain period by RDY input, the reset is accepted forcibly without waiting the completion of instruction. Forcible reset is accepted within 16 machine cycles.

When returning to the main clock mode by the external reset pin ( $\overline{RST}$  pin) from the stop mode, sub-clock mode, sub-sleep mode, and watch mode, input L level for at least oscillation time of oscillator\* + 100  $\mu$ s.

\*: Oscillation time of oscillator is the time that amplitude reaches 90%. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks

When returning to the main clock mode by the external reset pin ( $\overline{RST}$  pin) from the timebase timer mode, input L level for at least 100  $\mu$ s.

#### Software reset

A software reset is generated an internal reset by writing "0" to the RST bit of the low-power consumption mode control register (LPMCR). The oscillation stabilization wait time is not required for a software reset.

#### Watchdog reset

A watchdog reset is generated by a watchdog timer overflow that occurs when "0" is not written to the WTE bit of the watchdog timer control register (WDTC) within a given time after the watchdog timer is activated. The oscillation stabilization wait time is not required for watchdog reset.

#### Low voltage detection reset

The low voltage detection reset is generated when the low voltage (4.0 V  $\pm$  0.3 V) is detected.

The oscillation stabilization wait time is not required for the low voltage detection reset.

#### CPU operation detection reset

The CPU operation detection reset is 20-bit counter that the source oscillation is count-locked. If the CL bit of the low voltage/CPU operation detection reset is not cleared within a specified time after activation, the reset is generated.

The oscillation stabilization wait time is not required for the CPU operation detection reset.

#### Clock supervisor reset

When the failure of the main clock/subclock is detected, the clock supervisor reset is generated.

The oscillation stabilization wait time is not required for the clock supervisor reset.

#### **Definition of clocks**

HCLK: Oscillation clock frequency

MCLK: Main clock frequency

φ: Machine clock (CPU operating clock) frequency

1/φ: Machine cycle (CPU operating clock period)

See "5.1 Clocks", for details.

#### Note:

When the reset is occurred in the stop mode or sub-clock mode, the oscillation stabilization wait time of  $2^{15}$ /HCLK (approx. 8.19 ms, using at HCLK = 4 MHz oscillation) is required.

See "5.6 Oscillation Stabilization Wait Interval" for details.

## 7.2 Reset Cause and Oscillation Stabilization Wait Times

The MB90360 series has seven reset causes. The oscillation stabilization wait time for a reset depends on the reset cause.

#### ■ Reset Causes and oscillation Stabilization Wait Times

Table 7.2-1 summarizes reset causes and oscillation stabilization wait times.

Table 7.2-1 Reset Causes and oscillation Stabilization Wait Times

| Reset                      | Reset cause                                                                 | Oscillation stabilization wait time The parenthesized values are provided when oscillation clock frequency operates at 4 MHz |
|----------------------------|-----------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|
| Power-on                   | Power-on                                                                    | 2 <sup>16</sup> /HCLK (approx. 16.38 ms)                                                                                     |
| Watchdog                   | Watchdog timer overflow                                                     | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |
| External                   | L input from RST pin                                                        | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |
| Software                   | Write "0" to RST bit of low-power consumption mode control register (LPMCR) | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |
| Low voltage detection *1   | When low voltage is detected                                                | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |
| CPU operation detection *1 | When CPU operation detection counter overflows                              | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |
| Clock supervisor *2        | When failure of main clock/subclock is detected                             | None Note: However, the WS1 and WS0 bits are initialized to "11".                                                            |

HCLK: Oscillation clock frequency

WS1, WS0: Oscillation stabilization wait time select bit of clock selection register (CKSCR)

Figure 7.2-1 shows the oscillation stabilization wait times at a power-on reset.

<sup>\*1:</sup> Product with T-suffix

<sup>\*2:</sup> For MB90F367/T(S), MB90367/T(S)



Figure 7.2-1 Oscillation Stabilization Wait Times at a Power-on Reset

#### Note:

Ceramic and crystal oscillators generally require an oscillation stabilization wait time of several milliseconds to some tens of milliseconds, until stabilization at a natural frequency is attained after starts oscillation. A proper oscillation stabilization wait time must be set for the particular oscillator used.

See "5.6 Oscillation Stabilization Wait Interval", for details about oscillation stabilization wait times.

#### ■ Oscillation Stabilization Wait and Reset State

A reset operation in response to a power-on reset and other resets during stop mode or sub-clock mode is performed after the oscillation stabilization wait time has elapsed. This time interval is generated by the timebase timer. If the external reset has not been cleared after the interval, the reset operation is performed after the external reset is cleared.

#### 7.3 **External Reset Pin**

The external reset pin (RST pin) is an input pin used exclusively for a reset. Inputting an L level signal generates an internal reset. For the MB90360-series, resets are generated in synchronization with the CPU operating clock. However, initialization of external pin is asynchronous with the CPU operating clock.

#### ■ Block Diagrams of the External Reset Pin

Block diagram of the external reset pin

CPU operating clock (PLL multiplication circuit, 2-frequency division of HCLK) RST Synchronization Pin peripheral function circuit Input buffer Nch 7 External pin HCLK: Oscillation clock

Figure 7.3-1 Block Diagram of the External Reset Pin

#### Note:

Inputs to the  $\overline{RST}$  pin are accepted during cycles in which memory is not affected to prevent memory from being destroyed by a reset during a write operation.

A clock is required to initialize the internal circuit. In particular, an operation with an external clock requires clock input together with reset input.

# 7.4 Reset Operation

When the reset signal is inactivated, the reset vector and mode data is fetched from the predetermined locations depending on the setting of the mode pins. This operation, the mode fetch, then defines the operation mode of the CPU and the start address of the first instruction. For the power on reset, reset from the stop mode or sub-clock mode, the mode fetch is performed after the oscillation stabilization wait time is elapsed.

#### **■** Overview of Reset Operation

Figure 7.4-1 shows the reset operation flow.



#### ■ Mode Pins

Setting the mode pins (MD0 to MD2) specifies how to fetch the reset vector and the mode data. Fetching the reset vector and the mode data is performed in the reset sequence. See "9.1.1 Mode Pins", for details on mode pins.

#### **■** Mode Fetch

When the reset is cleared, the CPU transfers the reset vector and the mode data to the appropriate registers in the CPU core by hardware. The reset vector and mode data are allocated to the four bytes from "FFFFDC $_H$ " to "FFFFDF $_H$ ". The CPU outputs these addresses to the bus immediately after the reset is cleared and then fetches the reset vector and mode data. Using mode fetching, the CPU can begin processing at the address indicated by the reset vector.

Figure 7.4-2 shows the transfer of the reset vector and mode data.



Figure 7.4-2 Transfer of Reset Vector and Mode Data

#### Mode data (address: FFFFDF<sub>H</sub>)

Only a reset operation changes the contents of the mode register. The mode register setting is valid after a reset operation. See "9.1.2 Mode Data", for details on mode data.

#### Reset vector (address: FFFFDC<sub>H</sub> to FFFFDE<sub>H</sub>)

The reset vector points to the start address after the reset operation. The CPU starts to execute the first instruction stored in the start address.

## 7.5 Reset Cause Bits

## A reset cause can be identified by reading the watchdog timer control register (WDTC).

#### ■ Reset Cause Bits

As shown in Figure 7.5-1, a flip-flop is associated with each reset cause. The contents of the flip-flops are obtained by reading the watchdog timer control register (WDTC). If the cause of a reset must be identified after the reset has been cleared, the value read from the WDTC should be processed by the software and a branch made to the appropriate program.



Figure 7.5-1 Block Diagram of Reset Cause Bits

#### ■ Correspondence between reset cause bits and reset causes

Figure 7.5-2 shows the configuration of the reset cause bits of the watchdog timer control register (WDTC). Table 7.5-1 maps the correspondence between the reset cause bits and reset causes. See "Watchdog timer control register (WDTC)" in "12.1 Overview of Watchdog Timer", for details.

Figure 7.5-2 Configuration of Reset Cause Bits (watchdog timer control register)



Table 7.5-1 Correspondence between Reset Cause Bits and Reset Causes

| Reset cause                                                                                                                                                                                                | PONR | WRST | ERST | SRST |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|------|------|
| Generation of power-on reset request                                                                                                                                                                       | 1    | X    | X    | X    |
| Generation of reset request due to watchdog timer overflow                                                                                                                                                 | Δ    | 1    | Δ    | Δ    |
| External reset request from RST pin,  Low voltage detection reset (product with T-suffix)*1  CPU operation detection reset (product with T-suffix)*2  Clock supervisor reset (MB90F367/T(S), MB90367/T(S)) | Δ    | Δ    | 1    | Δ    |
| Generation of software reset request                                                                                                                                                                       | Δ    | Δ    | Δ    | 1    |

 $<sup>\</sup>Delta$ : Previous state retained

X: Undefined

<sup>\*1:</sup> When the low voltage detection reset request is used, the CPUF bit of the low voltage/CPU operation detection reset control register (LVRC) is also set to "1".

<sup>\*2:</sup> When the CPU operation detection reset request is used, the CPUF bit of the low voltage/CPU operation detection reset control register (LVRC) is also set to "1".

#### ■ Status of Reset Cause Bit and Low Voltage Detection Bit



Figure 7.5-3 Status of Reset Cause Bit and Low Voltage Detection Bit

#### (1) At power-on

Power-on reset bit (PONR), ERST, and LVRF are set to "1" at power on.

#### (2) Bit clear

Bit is cleared by reading the WDTC register and by writing "0" to LVRF.

#### (3) At low voltage detection (4.0 V $\pm$ 0.3 V)

The LVRF and ERST bits are set to "1" at low voltage detection of  $V_{CC}$  = 4.0 V  $\pm$  0.3 V.

#### (4) Bit clear

Bit is cleared by reading the WDTC register and by writing "0" to LVRF.

<sup>\*:</sup> The LVRF bit exist in the low voltage/CPU operation detection reset control register (LVRC).

#### ■ Notes about Reset Cause Bits

#### Multiple reset causes generated at the same time

When multiple reset causes are generated at the same time, the corresponding reset cause bits of the watchdog timer control register (WDTC) are also set to "1". If, for example, an external reset request via the  $\overline{RST}$  pin and the watchdog timer overflow occur at the same time, the ERST and the WRST bits are both set to "1".

#### Power-on reset

For a power-on reset, because the PONR bit is set to "1" but all other reset cause bits are undefined, the software should be programmed so that it will ignore all reset cause bits except the PONR bit if it is "1".

#### Clearing the reset cause bits

The reset cause bits are cleared only when the watchdog timer control register (WDTC) is read. Any bit corresponding to a reset cause that has already been generated is not cleared even though another reset is generated (a setting of "1" is retained).

#### Note:

If the power is turned on under conditions where no power-on reset occurs, the value in WDTC register may not be guaranteed.

## 7.6 Status of Pins in a Reset

#### This section describes the status of pins when a reset occurs.

#### ■ Status of Pins during a Reset

The status of pins during a reset depends on the settings of mode pins (MD2 to MD0).

About status of each pins during reset, please see "8.7 Status of Pins in Standby Mode and during Hold and Reset".

When internal vector mode has been set: (MD2 to MD0 = "011<sub>B</sub>")

All I/O pins (resource pins) are high impedance, and mode data is read from the internal ROM.

#### ■ Status of Pins after Mode Data is Read

The status of pins after mode data has been read depends on the mode data (M1 and M0).

■ When single-chip mode has been selected (M1, and M0 = "00<sub>B</sub>")

All I/O pins (resource pins) are high impedance, and mode data is read from the internal ROM.

#### Note:

For those pins that change to high impedance when a reset cause is generated, confirm that devices connected to the pins do not malfunction.

# **CHAPTER 8**

# LOW-POWER CONSUMPTION MODE

This chapter explains the low-power consumption mode of MB90360 series microcontrollers.

- 8.1 Overview of Low-Power Consumption Mode
- 8.2 Block Diagram of the Low-Power Consumption Control Circuit
- 8.3 Low-Power Consumption Mode Control Register (LPMCR)
- 8.4 CPU Intermittent Operation Mode
- 8.5 Standby Mode
- 8.6 Status Change Diagram
- 8.7 Status of Pins in Standby Mode and during Hold and Reset
- 8.8 Usage Notes on Low-Power Consumption Mode

# 8.1 Overview of Low-Power Consumption Mode

The MB90360 series has the following CPU operating modes, any of which can be used depending on operating clock selection and clock oscillation control:

- Clock mode : main clock mode, PLL clock mode, or sub-clock mode
- CPU intermittent operating mode: main clock intermittent operating mode, PLL clock

intermittent operating mode, or sub-clock intermittent

operating mode

Standby mode : sleep mode, stop mode, watch mode, or timebase

timer mode

## **■ CPU Operating Modes and Current Consumption**

Figure 8.1-1 shows the relationship between the CPU operating modes and current consumption.



#### ■ Clock Mode

#### PLL clock mode

In this mode, a PLL clock that is a multiple of the oscillation clock (HCLK) is used to operate the CPU and peripheral functions.

#### Main clock mode

In this mode, the main clock, with the oscillation clock (HCLK) frequency divided by 2 is used to operate the CPU and peripheral functions. In the main clock mode, the PLL multiplier circuit is inactive.

#### Sub-clock mode

In this mode, the sub-clock (SCLK) is used to operate the CPU and peripheral functions. The sub-clock can select a clock frequency divided by 2 or 4 of clock from external sub-clock pin or internal CR oscillation clock.

In the sub-clock mode, the main clock and PLL multiplier circuit are inactive.

The subclock oscillation stabilization wait time of 2<sup>14</sup>/SCLK (Approx. 2 s @32.768 kHz oscillation clock frequency, 1/4 division) takes place when power-on and reactivation from stop mode. If a transition from main clock mode to subclock mode is performed during this oscillation stabilization wait time, actual transition may be delayed.

#### Reference:

For the clock mode, see "5.5 Clock Mode".

#### **■ CPU Intermittent Operating Mode**

In this mode, the CPU is operated intermittently while high-speed clock pluses are supplied to peripheral functions, thereby reducing power consumption. In this mode, intermittent clock pulses are supplied only to the CPU while it is accessing a register, internal memory, peripheral function, or external unit.

#### ■ Standby Mode

In this mode, the standby control circuit stops supplying the clock to the CPU or peripheral functions or stops the oscillation clock itself (HCLK), thereby reducing power consumption.

#### Sleep mode

The sleep mode stops the operation clock to the CPU during operation in each clock mode. The CPU stops, and the peripheral function operates the clock before the transition to the sleep mode. The sleep mode is divided into the main sleep mode, PLL sleep mode before the transition to sleep mode.

#### Watch mode

The watch mode operates the sub-clock (SCLK), watch timer, and low voltage detection circuit only. The main clock and PLL clock stop. All peripheral functions other than the watch timer and low voltage detection circuit stop.

#### CHAPTER 8 LOW-POWER CONSUMPTION MODE

#### Timebase timer mode

The timebase timer mode operates the oscillation clock (HCLK), sub-clock (SCLK), timebase timer, watch timer, and low voltage detection circuit only. All peripheral functions other than the timebase timer, watch timer, and low voltage detection circuit stop.

#### Stop mode

The stop mode stops the oscillation clock (HCLK) and sub-clock (SCLK) during operation in each clock mode, and all functions other than low voltage detection circuit stop. Data can be retained at the lowest power consumption.

#### Note:

When the clock mode is switched, do not switch to other clock mode and low-power consumption mode before this switching is completed. Confirm the completion of clock mode switching by referring to the MCM and SCM bits of the clock selection register (CKSCR).

If the mode is switched to other clock mode and low-power consumption mode before completion of switching, the mode may not be switched.

# 8.2 Block Diagram of the Low-Power Consumption Control Circuit

This section shows the block diagram of the low-power consumption control circuit.

#### ■ Block Diagram of the Low-Power Consumption Control Circuit

Figure 8.2-1 Block Diagram of the Low-Power Consumption Control Circuit



#### CPU intermittent operation selector

This selector selects the halt cycle count of the CPU clock during the CPU intermittent operation mode.

#### Standby control circuit

CPU clock control and peripheral clock control circuits switch the CPU operation clock and peripheral function operation clock to transit to and cancel the standby mode.

#### CHAPTER 8 LOW-POWER CONSUMPTION MODE

#### CPU clock control circuit

This circuit controls clocks supplied to the CPU.

#### Pin high-impedance control circuit

This circuit makes I/O pins high-impedance in the watch mode, timebase timer mode and stop mode.

#### Internal reset generation circuit

This circuit generates an internal reset signal.

#### Low-power consumption mode control register (LPMCR)

This register is used to switch to and release the standby mode and to set the CPU intermittent operation mode.

# 8.3 Low-Power Consumption Mode Control Register (LPMCR)

This register switches to or releases the low-power consumption mode. This register also generates the internal reset signal and sets the halt cycle count during the CPU intermittent operation mode.

#### ■ Low-Power Consumption Mode Control Register (LPMCR)

Figure 8.3-1 Configuration of the Low-power Consumption Mode Control Register (LPMCR)



Table 8.3-1 Functions of Low-power Consumption Mode Control Register (LPMCR)

|              | Bit name                                               | Function                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7         | STP:<br>Stop mode bit                                  | This bit transits to the stop mode.  When the bit is set to "0": No effect.  When the bit is set to "1": The CPU enters the stop mode.  Read: "0" is always read.  • The bit is initialized to "0" when a reset or external interrupt occurs.                                                                                                                                  |
| bit6         | SLP:<br>Sleep mode bit                                 | This bit shift to sleep mode  When the bit is set to "0": No effect.  When the bit is set to "1": The CPU enters the sleep mode.  Read: "0" is always read.  The bit is initialized to "0" when a reset or external interrupt occurs.  When the STP and SLP bits are set to "1" at the same time, the STP bit supersedes the SLP bit, causing a transition to stop mode.       |
| bit5         | SPL:<br>Pin state specification bit                    | The bit is used to set the state of input/output pins after transition to the stop mode, watch mode, or timebase timer mode.  When the bit is set to "0": The current level of input/output pins is held.  When the bit is set to "1": The I/O pins enter a high impedance state.  • The bit is initialized to "0" at a reset.                                                 |
| bit4         | RST:<br>Internal reset signal<br>generation bit        | This bit generates software reset.  When the bit is set to "0": An internal reset signal for three machine cycles is generated.  When the bit is set to "1": No effect  Read: "1" is always read.                                                                                                                                                                              |
| bit3         | TMD:<br>Watch mode bit                                 | This bit shift to watch mode or timebase timer mode  When the bit is set to "0": If the main clock mode or PLL clock mode is used, the bit transits to the timebase timer mode.  If the sub-clock mode is used, the bit transits to the watch mode.  When the bit is set to "1": No effect  The bit is set to "1" when a reset or interrupt occurs.  Read: "1" is always read. |
| bit1<br>bit2 | CG1, CG0:<br>CPU suspended cycle<br>number select bits | These bits are used to set the halt cycle count of the CPU clock in the CPU intermittent operation mode.  • Any reset causes the bit to return to the reset value.                                                                                                                                                                                                             |
| bit0         | Reserved: reserved bit                                 | Always set this bit to "0".                                                                                                                                                                                                                                                                                                                                                    |

#### Notes:

- Switching to a low-power consumption mode is performed by writing the low-power consumption mode control register (LPMCR). Only the instructions listed in Table 8.3-2 should be used for this purpose. If other instructions are used for switching to a low-power consumption mode, operation cannot be assured.
- The standby mode transition instruction in Table 8.3-2 must always be followed by an array of instructions highlighted by a line below.

```
MOV LPMCR, #H' xx ; The low-power consumption mode transition instruction in Table 8.3-2
NOP
NOP
JMP $+3
NOV A, #H' 10 ; jump to next instruction
any instruction
```

The devices does not guarantee its operation after returning from the standby mode if you place an array of instructions other than the one enclosed in the dotted line.

- To access the low-power consumption mode control register (LPMCR) with C language, refer to "■ Notes on Accessing the Low-Power Consumption Mode Control Register (LPMCR) to Enter the Standby Mode" in "8.8 Usage Notes on Low-Power Consumption Mode".
- When word-length is used for writing the low-power consumption mode control register (LPMCR), even addresses must be used. Using odd addresses to switch to a low-power consumption mode may result in a malfunction.
- To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode, watch mode or timebase timer mode, disable the output of peripheral functions, and set the STP bit of the LPMCR register to 1 or set the TMD bit of the LPMCR register to 0.

Table 8.3-2 Instructions to be Used for Switching to a Low-power Consumption Mode

| MOV  | io,#imm8     | MOV  | dir,#imm8  | MOV  | eam,#imm8  | VOM   | eam,Ri  |
|------|--------------|------|------------|------|------------|-------|---------|
| MOV  | io,A         | MOV  | dir,A      | MOV  | addr16,A   | MOV   | eam,A   |
| MOV  | @Rli+disp8,A |      |            |      |            |       |         |
| MOVW | io,#imm16    | MOVW | dir,#imm16 | MOVW | eam,#imm16 | MVVOM | eam,RWi |
| MOVW | io,A         | MOVW | dir,A      | MOVW | addr16,A   | MOVW  | eam,A   |
| MOVW | @Rli+disp8,A |      |            |      |            |       |         |
| SETB | io:bp        | SETB | dir:bp     | SETB | addr16:bp  |       |         |
| CLRB | io:bp        | CLRB | dir:bp     | CLRB | addr16:bp  |       |         |

# 8.4 CPU Intermittent Operation Mode

This mode is used for intermittent operation of the CPU while operation clock is supplied to the CPU and peripheral functions. The purpose of this mode is to reduce power consumption.

#### **■ CPU Intermittent Operation Mode**

This mode halts the supply of the clock pulse to the CPU for a certain period. The halt occurs after the execution of every instruction that accesses a register, internal memory, I/O, peripheral functions, or the external bus. Internal bus cycle activation is therefore delayed. While high-speed peripheral clock pulses are supplied to peripheral functions, the execution speed of the CPU is reduced, thereby enabling low-power consumption processing.

- The low-power consumption mode control register (LPMCR: CG1 and CG0) is used to select the number of machine cycles that halts the clock supplied to the CPU.
- Instruction execution time in the CPU intermittent operation mode can be calculated. A correction value should be obtained by multiplying the execution count of instructions that access a register, internal memory, internal peripheral functions, or the external bus by the number of clock pulses per halt cycle. Add this corrective value to the normal execution time. Figure 8.4-1 shows the operating clock pulses during the CPU intermittent operation mode.

Figure 8.4-1 Clock Pulses during the CPU Intermittent Operation Mode



# 8.5 Standby Mode

The standby mode causes the standby control circuit to either stop supplying an operation clock to the CPU or peripheral functions or to stop the oscillation clock reducing power consumption.

## **■** Operation Status during Standby Mode

Table 8.5-1 shows operation status during standby mode.

Table 8.5-1 Operation Status during Standby Mode

| Mode                      | name               | Transition conditions   | Oscillation<br>clock<br>(HCLK) | Sub-clock<br>(SCLK) | Machine<br>clock | CPU | Peripheral function | Pin        | Release<br>method             |
|---------------------------|--------------------|-------------------------|--------------------------------|---------------------|------------------|-----|---------------------|------------|-------------------------------|
| Sleep<br>mode             | Main sleep<br>mode | MCS=1<br>SCS=1<br>SLP=1 | 0                              | •                   | )                | ×   | •                   | •          | External reset or interrupt   |
|                           | Sub-sleep<br>mode  | MCS=X<br>SCS=0<br>SLP=1 | ×                              | )                   | )                | ×   | )                   | 0          | External reset or interrupt   |
|                           | PLL sleep mode     | MCS=0<br>SCS=1<br>SLP=1 | •                              | )                   | )                | ×   | Э                   | 0          | External reset or interrupt   |
| Timebase<br>timer<br>mode | SPL=0              | MCS=X<br>SCS=1<br>TMD=0 | •                              | )                   | ×                | ×   | <b>X</b> *1         | •          | External reset or interrupt*4 |
|                           | SPL=1              | MCS=X<br>SCS=1<br>TMD=0 | •                              | )                   | ×                | ×   | <b>X</b> *1         | Hi-Z<br>*3 | External reset or interrupt*4 |
| Watch<br>mode             | SPL=0              | MCS=X<br>SCS=0<br>TMD=0 | ×                              | )                   | ×                | ×   | <b>X</b> *2         | •          | External reset or interrupt*5 |
|                           | SPL=1              | MCS=X<br>SCS=0<br>TMD=0 | ×                              | Э                   | ×                | ×   | <b>X</b> *2         | Hi-Z<br>*3 | External reset or interrupt*5 |
| Stop<br>mode              | SPL=0              | STP=1                   | ×                              | ×                   | ×                | ×   | ×                   | •          | External reset or interrupt*6 |
|                           | SPL=1              | STP=1                   | ×                              | ×                   | ×                | X   | ×                   | Hi-Z<br>*3 | External reset or interrupt*6 |

#### CHAPTER 8 LOW-POWER CONSUMPTION MODE

O: operation, X: stop, ◆: held in the state before transiting, Hi-Z: High impedance

\*1: The timebase timer, watch timer, and low voltage detection function operate.

\*2 : The watch timer operates.

\*3 : The DTP/external interrupt input pin operates.

\*4: Watch timer, timebase timer, and external interrupts

\*5 : Watch timer and external interrupts

\*6: External interrupt

MCS: PLL clock select bit in clock selection register (CKSCR)

SCS: Subclock select bit in the clock selection register (CKSCR)

SPL: Pin state specification bit of low-power consumption mode control register (LPMCR)

 $SLP: Sleep \ mode \ bit \ of \ low-power \ consumption \ mode \ control \ register \ (LPMCR)$ 

STP: Stop mode bit of low-power consumption mode control register (LPMCR)

TMD: Watch mode bit of low-power consumption mode control register (LPMCR)

#### Note:

For those external pins shared between port functions and peripheral functions in the stop mode, watch mode, or timebase timer mode, disable output for the peripheral functions then set the STP bit to "1" or reset the TMD bit to "0" to set these pins in high impedance state.

# 8.5.1 Sleep Mode

This mode causes the CPU operating clock to stop during operation in each clock mode. The CPU stops, and peripheral function operates.

#### **■** Switching to Sleep Mode

Writing 1 in the SLP bit and 0 in the STP bit of the low-power consumption mode control register (LPMCR) triggers a switch to a sleep mode according to setting of the MCS and SCS bits in the clock selection register (CKSCR). Table 8.5-2 shows the correspondence between MCS and SCS bits in the clock selection register (CKSCR) and sleep mode.

Table 8.5-2 Setting of Clock Selection Register (CKSCR) and Sleep Mode

| Clock selection r | egister (CKSCR) | Sleep mode to be switched |
|-------------------|-----------------|---------------------------|
| MCS               | SCS             |                           |
| 1                 | 1               | Main sleep mode           |
| 0                 | 1               | PLL sleep mode            |
| 1                 | 0               | Sub-sleep mode            |
| 0                 | 0               | Sub-steep mode            |

#### Note:

When 1 is written to the SLP and STP bits of the low-power consumption mode control register (LPMCR) at the same time, the STP bit setting overrides the SLP bit setting and the mode switches to the stop mode. When 1 is written to the SLP bit and 0 is written to the TMD bit at the same time, the TMD bit setting overrides the SLP bit setting and the mode switches to the timebase timer mode or watch mode.

#### Data retention function

In a sleep mode, the contents of dedicated registers, such as accumulators, and the internal RAM are retained.

#### Operation during an interrupt request

Writing 1 in the SLP bit of the low-power consumption mode control register (LPMCR) during an interrupt request does not trigger a switch to a sleep mode. If the CPU does not accept the interrupt request, the CPU executes the next to currently executing instruction. If the CPU accepts the interrupt request, CPU operation immediately branches to the interrupt processing routine.

#### Status of pins

During a sleep mode, all pins retain their previous status.

#### ■ Return from Sleep Mode

The sleep mode is cancelled by a reset factor or when an interrupt is generated.

#### Return by reset factor

When the sleep mode is cancelled by a reset factor, the mode transits to the main clock mode after the sleep mode is cancelled, transiting to the reset sequence.

#### Note:

- For returning from subsleep mode to main clock mode using the external reset pin (RST pin), input the Low level for at least oscillator's oscillation time\* + 100 µs + 16 machine cycles (main clock).
  - \*: The oscillation time for the oscillator is the period of time taken until its amplitude reaches 90%. It takes several to dozens of ms for crystal oscillators, hundreds of µs to several ms for FAR/ceramic oscillators, and 0 ms for external clocks.

#### Return by interrupt

When a higher interrupt request than the interrupt level (IL) of 7 is generated from the resources in the sleep mode, the sleep mode is cancelled. After the sleep mode is cancelled, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

- When the CPU is not ready to accept any interrupt request, the next instruction to the currently executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.

Figure 8.5-1 shows the release of a sleep mode when an interrupt occurs.



Figure 8.5-1 Release of Sleep Mode by Interrupt Occurrence

#### Note:

When interrupt processing is executed, the CPU normally executes the instruction that follows the instruction in which a sleep mode has been specified. The CPU then proceeds to interrupt processing.

#### 8.5.2 Watch Mode

This mode causes all functions, excluding the subclock (SCLK), watch timer, and low voltage detection circuit, to stop. Main clock and PLL clock stop.

#### ■ Switching to the Watch Mode

When 0 is written to the TMD bit of the low-power consumption mode control register (LPMCR) in the subclock run mode, switching to the watch mode occurs.

#### Data retention function

In the watch mode, the contents of the dedicated registers, such as accumulators, and the internal RAM are retained.

#### Operation during an interrupt request

Writing 1 in the TMD bit of the low-power consumption mode control register (LPMCR) during an interrupt request does not trigger a switch to the watch mode.

If the CPU is not ready to accept any interrupt request, the instruction next to currently executing instruction is executed. If the CPU is ready to accept any interrupt request, an interrupt operation immediately branches to the interrupt processing routine.

#### Status of pins

Whether the I/O pins in the watch mode retain the state they had immediately before switching to the watch mode or go to the high-impedance state can be controlled by the SPL bit of the low-power consumption mode control register (LPMCR).

#### Note:

To set the pin that is shared the peripheral function and port to the high impedance in the watch mode, disable the output of peripheral function, then set the TMD bit of the low-power consumption mode control register (LPMCR) to "0".

#### ■ Return from Watch Mode

The watch mode is cancelled by a reset factor or when an interrupt is generated.

#### Return by reset factor

When the watch mode is cancelled by a reset factor, the mode transits to the main clock mode after the watch mode is cancelled, transiting to the reset sequence.

#### Return by interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from the watch timer and external interrupt in the watch mode, the watch mode is cancelled. After the watch mode is cancelled, as with normal interrupt processing, the generated interrupt request is

identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR). In the sub-watch mode, no oscillation stabilization wait time is generated and the interrupt request is identified immediately after return from the watch mode.

- When the CPU is not ready to accept any interrupt request, the next instruction to the currently executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.

#### Note:

When interrupt processing is executed, the CPU normally executes the instruction following the instruction in which the watch mode has been specified. The CPU then proceeds to interrupt processing.

## 8.5.3 Timebase Timer Mode

This mode causes all functions, excluding oscillation clock (HCLK), subclock (SCLK), the timebase timer, the watch timer, and low voltage detection circuit, to stop. In this mode, only the timebase timer, watch timer, and low voltage detection circuit, operate.

#### ■ Switching to the Timebase Timer Mode

When 0 is written to the TMD bit of the low-power consumption mode control register (LPMCR) in the PLL clock mode or main clock mode (CKSCR: SCM = 1), switching to the timebase timer mode occurs.

#### Data retention function

In the timebase timer mode, the contents of dedicated registers, such as accumulators, and the internal RAM are retained.

#### Operation during an interrupt request

Writing 0 in the TMD bit of the low-power consumption mode control register (LPMCR) during an interrupt request does not trigger a switch to the timebase timer mode.

If the CPU is not ready to accept any interrupt request, the instruction next to currently executing instruction is executed. If the CPU is ready to accept any interrupt request, an interrupt operation immediately branches to the interrupt processing routine.

#### Status of pins

Whether the I/O pins in the timebase timer mode retain the state they had immediately before switching to the timebase timer mode or go to the high-impedance state can be controlled by the low-power consumption mode control register (LPMCR: SPL).

#### Note:

To set the pin that is shared the peripheral function and port to the high impedance in the timebase timer mode, disable the output of the peripheral function, then set the TMD bit of the low-power consumption mode control register (LPMCR) to "0".

#### ■ Return from Timebase Timer Mode

The timebase timer mode is cancelled by a reset factor or when an interrupt is generated.

#### Return by reset factor

When the timebase timer mode is cancelled by a reset factor, the mode transits to the main clock mode after the timebase timer mode is cancelled, transiting to the reset sequence.

#### Return by interrupt

When an interrupt request higher than interrupt level (IL) of 7 is generated from the watch timer, timebase timer, and external interrupt in the timebase timer mode, the timebase timer mode is cancelled. After the timebase timer mode is cancelled, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

- When the CPU is not ready to accept any interrupt request, the next instruction to the currently executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.
- The following two timebase timer modes are available:
  - Main clock ←→ timebase timer mode
  - PLL clock  $\longleftrightarrow$  timebase timer mode

#### Note:

When interrupt processing is executed, the CPU normally executes the instruction following the instruction in which switching to the timebase timer mode has been specified. The CPU then proceeds to interrupt processing.

# 8.5.4 Stop Mode

Because this mode causes oscillation clock (HCLK) and subclock (SCLK) to stop during operation in each clock mode, data can be retained by the lowest power consumption.

#### ■ Stop Mode

When 1 is written to the STP bit of the low-power consumption mode control register (LPMCR) during operation in the PLL clock mode (CKSCR: MCS=1, SCS=0), the mode transits to the stop mode according to the settings of the MCS bit and SCS bit in the clock selection register (CKSCR).

Table 8.5-3 shows the settings of the MCS and SCS bits in the clock selection register (CKSCR) and the stop modes.

Table 8.5-3 Clock Selection Register (CKSCR) Settings and Stop Modes

| Clock selection r | egister (CKSCR) | Stop Made to be Transited |  |
|-------------------|-----------------|---------------------------|--|
| MCS               | SCS             | Stop Mode to be Transited |  |
| 1                 | 1               | Main stop mode            |  |
| 0                 | 1               | PLL stop mode             |  |
| 1                 | 0               | - Sub-stop mode           |  |
| 0                 | 0               |                           |  |

#### Note:

If both the STP and SLP bits in the low-power consumption mode control register (LPMCR) are set to "1" simultaneously, the STP bit is preferred and the mode transits to the stop mode.

#### Data retention function

In the stop mode, the contents of the dedicated registers, such as accumulators, and the internal RAM are retained.

#### Operation during an interrupt request

Writing 1 in the STP bit of the low-power consumption mode control register (LPMCR) during an interrupt request does not trigger a switch to the stop mode.

If the CPU is not ready to accept any interrupt request, the instruction next to currently executing instruction is executed. If the CPU is ready to accept any interrupt request, an interrupt operation immediately branches to the interrupt processing routine.

#### Status of pins

Whether the I/O pins in the stop mode retain the state they had immediately before switching to the stop mode or go to the high-impedance state can be controlled by the SPL bit of the low-power consumption mode control register (LPMCR).

#### Note:

For those external pins shared between port functions and peripheral functions, disable output for the peripheral functions then set the STP bit to "1" to set these pins in high impedance state.

#### ■ Return from Stop Mode

The stop mode is cancelled by a reset factor or when an interrupt is generated. At return from the stop mode, the oscillation clock (HCLK) and the sub clock (SCLK) stop, so the stop mode is cancelled after the elapse of the main clock oscillation stabilization wait time or the sub clock oscillation stabilization wait time.

#### Return by reset factor

When the stop mode is cancelled by a reset factor, the main clock oscillation stabilization wait time is generated. After the termination of the main clock oscillation stabilization wait time, the stop mode is cancelled, transiting to the reset sequence.

Figure 8.5-2 shows the return from the sub-stop mode by an external reset.

RST pin Stop mode Main clock During oscillation Oscillation stabilization wait Subclock **During oscillation** Oscillation stabilization wai Oscillation stabilization wait During oscillation PLL clock CPU operation clock Main clock PLL clock During stop **CPU** operation Reset sequence Normal process Cancellation of stop mode Cancellation of reset

Figure 8.5-2 Return from the Sub-stop Mode by an External Reset

#### Return by interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from external interrupt in the stop mode, the stop mode is cancelled. In the stop mode, the main clock oscillation stabilization wait time or the sub clock oscillation stabilization wait time is generated after the stop mode is cancelled. After the termination of the main clock oscillation stabilization wait time or subclock oscillation stabilization wait time, as with normal interrupt processing, the generated interrupt request is identified according to the settings of the I flag in the condition code register (CCR), the interrupt level mask register (ILM), and the interrupt control register (ICR).

- When the CPU is not ready to accept any interrupt request, the instruction next to the currently
  executing instruction is executed.
- When the CPU is ready to accept any interrupt request, it immediately branches to the interrupt processing routine.

#### **Notes:**

- When interrupt processing is executed, the CPU normally executes the instruction following the instruction in which the stop mode has been specified. The CPU then proceeds to interrupt processing. When transiting to the PLL stop mode, set the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) to "10<sub>B</sub>" or "11<sub>B</sub>".
- In PLL stop mode, the main clock and PLL multiplication circuit stop. During recovery from PLL stop mode, it is necessary to allot the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait times for the main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0). The oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) must be selected accordingly to account for the longer of main clock and PLL clock oscillation stabilization wait time. The PLL clock oscillation stabilization wait time, however, requires 2<sup>14</sup>/HCLK or more. Set the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) to "10<sub>B</sub>" or "11<sub>B</sub>".

# 8.6 Status Change Diagram

Figure 8.6-1 shows the operation status and status transition in the clock mode and standby mode of the MB90360 series.

#### **■** Status Change Diagram



# 8.7 Status of Pins in Standby Mode and during Hold and Reset

The status of I/O pins in the standby mode and during hold and reset are described for each memory access mode.

#### ■ Status of I/O Pins (Single-chip Mode)

Table 8.7-1 Status of I/O Pins (Single-chip Mode)

| Pin Name                                                                        | At aloon                           | At stop/watch/                                      | At a reset                                              |                                 |
|---------------------------------------------------------------------------------|------------------------------------|-----------------------------------------------------|---------------------------------------------------------|---------------------------------|
| Fill Name                                                                       | At sleep                           | SPL=0                                               | SPL=1                                                   | At a reset                      |
| P27 to P20<br>P44, P43, P41, P40<br>P53 to P50<br>P67 to P60<br>P87 to P85, P83 | Immediately preceding state held*2 | Input cut off*4/ immediately preceding state held*2 | Input cut off <sup>*4</sup> / output Hi-Z <sup>*5</sup> | Input disabled*3/ output Hi-Z*5 |
| P42 <sup>*7</sup><br>P54 to P57<br>P80, P82, P84 <sup>*7</sup>                  | preceding state field              | Input enabled*1                                     |                                                         | output m-Z                      |

<sup>\*1:</sup> Input enabled means that input function can be used. When the pin is set as input port, handle the pull-up/pull-down or input the external signal. When the pin is set as output port, the pin is set to the same state as other pins.

#### Note:

To set that pin to high impedance which serves either for a peripheral resource or as a port in stop mode, watch mode, or timebase timer mode, disable the output of the peripheral resource, then set the STP bit to "1" or set the TMD bit to "0" in the low-power consumption mode control register (LPMCR).

<sup>\*2:</sup> Indicates that either the output pins output their state as it is immediately before entering each standby mode or the input pins are input-disabled. Output of the output state as it is means that when the resource with an output is in operation, the state of pins is output according to the state of the resource and, when the state of output pins is output, it is held.

<sup>\*3:</sup> Input disabled means that no pin value can be accepted internally because the internal circuit is off while the operation of the input gates of pins is enabled.

<sup>\*4:</sup> Input cut off means that the operation of the input gates of pins is disabled.

<sup>\*5:</sup> Output Hi-Z means that the driving of pin driving transistors is disabled to place the pins in a high impedance state.

<sup>\*6:</sup> In these modes, the pull-up function of the port 2 is invalid.

<sup>\*7:</sup> When the INTxR bit of the external interrupt cause selection register (EISSR) is set to "1", these pins become "input enabled" in stop mode. When the bit is set to "0", they become the same state as other pins.

# 8.8 Usage Notes on Low-Power Consumption Mode

#### This section explains the notes when using the low-power consumption modes.

#### **■** Transition to Standby Mode

When an interrupt request is generated from the resource to the CPU, the mode does not transit to each standby mode even after setting the STP and SLP bits to 1 and the TMD bit to 0 in the low-power consumption mode control register (LPMCR) (and also even after interrupt processing).

If the CPU is servicing an interrupt, the interrupt-service-time interrupt request flag is cleared and the CPU can enter the standby mode unless any other interrupt request has been generated.

#### ■ Notes on the Transition to Standby Mode

To set a pin to high impedance when the pin is shared by a peripheral function and a port in stop mode, watch mode, or timebase timer mode, use the following procedure:

- 1. Disable the output of peripheral functions.
- 2. Set the SPL bit to "1", STP bit to "1", or TMD bit to "0" in the low-power consumption mode control register (LPMCR).

#### ■ Cancellation of Standby Mode by Interrupt

When an interrupt request higher than the interrupt level (IL) of 7 is generated from the resource and external interrupt during operation in the sleep mode, watch mode, timebase timer mode, or stop mode, the standby mode is cancelled. The standby mode is cancelled by an interrupt regardless of whether the CPU accepts interrupts or not.

#### Note:

To prevent the CPU from causing a branch to interrupt servicing immediately after returning from standby mode, take measures, such as disabling interrupts before setting the standby mode.

#### ■ Note on Canceling Standby Mode

The standby mode can be cancelled by an input according to the settings of an input factor of an external interrupt. The input factor can be selected from High level, Low level, rising edge, and falling edge.

#### ■ Oscillation Stabilization Wait Time

#### Oscillation stabilization wait time of main clock

In the sub clock mode, watch mode, or stop mode, the oscillation of the main clock stops and the oscillation stabilization wait time of the main clock is required. The oscillation stabilization wait time of the main clock is set by the WS1 and WS0 bits in the clock selection register (CKSCR).

#### Oscillation stabilization wait time of sub clock

In the sub-stop mode, the oscillation of the sub clock (SCLK) stops and the oscillation stabilization wait time of the sub clock is required. The oscillation stabilization wait time of the sub clock is fixed at  $2^{14}$ / SCLK (SCLK: sub clock).

#### PLL clock oscillation stabilization wait time

In main clock mode, the PLL multiplication circuit stops. When changing to PLL clock mode, it is necessary to reserve the PLL clock oscillation stabilization wait time. The CPU runs in main clock mode till the PLL clock oscillation stabilization wait time has elapsed. When the main clock mode is switched to PLL clock mode, the PLL clock oscillation stabilization wait time is fixed at 2<sup>14</sup>/HCLK (HCLK: oscillation clock).

In sub-clock mode, the main clock and PLL multiplication circuit stop. When changing to PLL clock mode, it is necessary to reserve the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait time for main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0). The oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) must be selected accordingly to account for the longer of the main clock and PLL clock oscillation stabilization wait time. The PLL clock oscillation stabilization wait time, however, requires  $2^{14}$ /HCLK or more. Set the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) to " $10_{\rm R}$ " or " $11_{\rm R}$ ".

In PLL stop mode, the main clock and PLL multiplication circuit stop. During recovery from PLL stop mode, it is necessary to allot the main clock oscillation stabilization wait time and PLL clock oscillation stabilization wait time. The oscillation stabilization wait time for the main clock and PLL clock are counted simultaneously according to the value specified in the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0). The oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) must be selected accordingly to account for the longer of main clock and PLL clock oscillation stabilization wait time. The PLL clock oscillation stabilization wait time, however, requires  $2^{14}$ /HCLK or more. Set the oscillation stabilization wait time selection bits in the clock selection register (CKSCR: WS1, WS0) to "10<sub>B</sub>" or "11<sub>B</sub>".

#### ■ Clock Mode Switching

When the clock mode is switched, do not switch to other clock mode and low-power consumption mode before this switching is completed. Confirm the completion of clock mode switching by referring to the MCM and SCM bits of the clock selection register (CKSCR).

If the mode is switched to other clock mode or low-power consumption mode before completion of switching, the mode may not be switched.

# ■ Notes on Accessing the Low-Power Consumption Mode Control Register (LPMCR) to Enter the Standby Mode

To access the low-power consumption mode control register (LPMCR) with assembler language

To set the low-power consumption mode control register (LPMCR) to enter the standby mode, use the instruction listed in Table 8.3-2.

The standby mode transition instruction in Table 8.3-2 must always be followed by an array of instructions highlighted by a line below.

MOV LPMCR, #H' xx; The low-power consumption mode transition instruction in Table 8.3-2

The devices does not guarantee its operation after returning from the standby mode if you place an array of instructions other than the one enclosed in the line.

To access the low-power consumption mode control register (LPMCR) with C language

To enter the standby mode using the low-power consumption mode control register (LPMCR), use one of the following methods 1. to 3. to access the register:

1. Specify the standby mode transition instruction as a function and insert two \_\_wait\_nop() built-in functions after that instruction. If any interrupt other than the interrupt to return from the standby mode can occur within the function, optimize the function during compilation to suppress the LINK and UNLINK instructions from occurring.

Example: Watch mode or timebase timer mode transition function

```
void enter_watch(){
    IO_LPMCR.byte = 0x10; /* Set LPMCR TMD bit to 0 */
    __wait_nop();
    __wait_nop();
}
```

2. Define the standby mode transition instruction using \_\_asm statements and insert two NOP and JMP instructions after that instruction.

Example: Transition to sleep mode

3. Define the standby mode transition instruction between #pragma asm and #pragma endasm and insert two NOP and JMP instructions after that instruction.

Example: Transition to stop mode

```
#pragma asm

MOV I:_IO_LPMCR, #H' 98 /* Set LPMCR STP bit to 1 */

NOP

NOP

JMP $+3 /* Jump to the next instruction */

#pragma endasm
```

#### CHAPTER 8 LOW-POWER CONSUMPTION MODE

# **CHAPTER 9**

# MEMORY ACCESS MODES

This chapter explains the functions and operations of the memory access modes.

9.1 Outline of Memory Access Modes

# 9.1 Outline of Memory Access Modes

In the F<sup>2</sup>MC-16LX, various modes are provided for access methods and access areas.

#### ■ Outline of Memory Access Modes

Table 9.1-1 Mode Pin and Mode

| Operation mode    | Bus mode    |
|-------------------|-------------|
| RUN mode          | Single-chip |
| Flash programming | _           |

#### Operation mode

Operation mode means the mode for controlling the device operation status. The operation mode is specified by the MDx mode setting pin and the Mx bit in mode data. By selecting an operation mode, normal operation activation or flash memory programming can be performed.

#### Bus mode

Bus mode means the mode for controlling the internal ROM operation and external access function. The bus mode is specified by the MDx mode setting pin and the Mx bit in mode data. The MDx mode setting pin specifies the bus mode for reading the reset vector and mode data, and the Mx bit in mode data specifies the bus mode for normal operation.

#### Run mode

Run mode means the CPU operation mode. The run mode has the main clock mode, PLL clock mode, and various low-power consumption mode. See CHAPTER 8 "LOW-POWER CONSUMPTION MODE" for details.

# 9.1.1 Mode Pins

Table 9.1-2 lists the operations that can be specified by combining the three external pins MD2 to MD0.

## **■ Mode Pins**

Table 9.1-2 Mode Pin and Mode

| Mod | le pin se | etting | Mode name                 | Reset vector External data access area bus width |                  | Remarks                                                              |  |  |  |
|-----|-----------|--------|---------------------------|--------------------------------------------------|------------------|----------------------------------------------------------------------|--|--|--|
| MD2 | MD1       | MD0    |                           | access area                                      | bus width        |                                                                      |  |  |  |
| 0   | 0         | 0      |                           |                                                  |                  |                                                                      |  |  |  |
| 0   | 0         | 1      |                           | \$                                               | Setting disabled |                                                                      |  |  |  |
| 0   | 1         | 0      |                           |                                                  |                  |                                                                      |  |  |  |
| 0   | 1         | 1      | Internal vector mode      | Internal                                         | (Mode data)      | Reset sequence and subsequent sequences are controlled by mode data. |  |  |  |
| 1   | 0         | 0      |                           |                                                  | Satting disabled |                                                                      |  |  |  |
| 1   | 0         | 1      |                           | Setting disabled                                 |                  |                                                                      |  |  |  |
| 1   | 1         | 0      | Flash serial programming* | _                                                | -                | _                                                                    |  |  |  |
| 1   | 1         | 1      | Flash memory              | _                                                | _                | Mode when parallel writer is used                                    |  |  |  |

<sup>\*:</sup> The serial programming of the flash memory cannot be written only by setting the mode pin. Other pin also need to be set. See "CHAPTER 25 EXAMPLES OF MB90F362/T(S), MB90F367/T(S) SERIAL PROGRAMMING CONNECTION" for details.

## 9.1.2 Mode Data

Mode data is stored at  $\mathsf{FFFDF}_\mathsf{H}$  of main memory and used for controlling the CPU operation. This data is fetched during a reset sequence and stored in the mode register inside the device. The mode register value can be changed only by a reset sequence. The setting of this register is valid after the reset sequence. Always set the reserved bits to "0".

#### ■ Mode Data

Figure 9.1-1 Mode Data Configuration



[bit7 and bit6] M1, M0 (bus mode setting bits)

The M1 and M0 bits are used to specify the operation mode after the reset sequence is completed. Table 9.1-3 shows the relationship between the M1 and M0 bits and the functions.

Table 9.1-3 Function of M1, M0 (bus mode setting bit)

| M1 | MO | Function         | Remarks |
|----|----|------------------|---------|
| 0  | 0  | Single-chip mode |         |
| 0  | 1  | Setting disabled |         |
| 1  | 0  |                  |         |
| 1  | 1  |                  |         |

## 9.1.3 Memory Space in Each Bus Mode

Figure 9.1-2 shows the correspondence between the access areas and physical addresses for each bus mode.

## ■ Memory Space in Each Bus Mode

Figure 9.1-2 Relationship between Access Areas and Physical Addresses for Each Bus Mode



| Product type                                               | Address #1          | Address #2          |
|------------------------------------------------------------|---------------------|---------------------|
| MB90F362/T(S), MB90362/T(S)<br>MB90F367/T(S), MB90367/T(S) | FF0000 <sub>H</sub> | 000D00 <sub>H</sub> |
| MB90V340A-101/102                                          | F80000 <sub>H</sub> | 007900 <sub>H</sub> |

## **■** Recommended Setting

Table 9.1-4 lists an example of recommended settings for mode pins and mode data.

Table 9.1-4 Recommended Setting Example of Mode Pin and Mode Data

| Setting example | MD2 | MD1 | MD0 | M1 | MO |
|-----------------|-----|-----|-----|----|----|
| Single-chip     | 0   | 1   | 1   | 0  | 0  |

External pins have signal functions that depend on each mode.

# CHAPTER 10 I/O PORTS

This chapter explains the functions and operations of the I/O ports.

10.1 I/O Ports

10.2 I/O Port Registers

## 10.1 I/O Ports

Each pin of the ports can be specified as input or output using the port direction register (DDR) if the corresponding peripheral does not use the pin. When a pin is specified as input, the logic level at the pin is read. When a pin is specified as output, the port data register value is read. The above also applies to a read operation for the read-modify-write instructions.

## ■ I/O Ports

When a pin is used as an output of other peripheral function, the logic level at the pin is read regardless of the port data register value.

It is generally recommended that the read-modify-write instructions should not be used for setting the port data register prior to setting the port as an output. This is because the read-modify-write instruction in this case results reading the logic level at the port rather than the register value.

Figure 10.1-1 is a block diagram of the I/O ports.



Figure 10.1-1 I/O Port Block Diagram

## 10.2 I/O Port Registers

There are five types of I/O port registers:

- Port data register (PDR2, PDR4 to PDR6, PDR8)
- Port direction register (DDR2, DDR4 to DDR6, DDR8, DDRA)
- Pull-up control register (PUCR2)
- Analog input enable register (ADER5, ADER6)
- Input level select register (ILSR0, ILSR1)

## **■ I/O Port Registers**

Figure 10.2-1 shows the I/O port registers.

#### Figure 10.2-1 I/O Port Registers Bit No. Address: 000002<sub>H</sub> Port 2 data register (PDR2) P26 P25 P24 P23 P22 P21 P20 Address: 000004<sub>H</sub> Port 4 data register (PDR4) P44 P43 P42 P41 P40 Port 5 data register (PDR5) Address: 000005<sub>H</sub> P56 P55 P51 P50 P54 P53 P52 Port 6 data register (PDR6) Address: 000006<sub>H</sub> P67 P60 P66 P65 P64 P63 P62 P61 Address: 000008<sub>H</sub> Port 8 data register (PDR8) P80 P87 P86 P85 P84 P83 P82 Bit No. 6 5 3 2 Address: 000012<sub>H</sub> Port 2 direction register (DDR2) D27 D26 D25 D21 D20 D24 D23 D22 Address: 000014<sub>H</sub> Port 4 direction register (DDR4) D44 D43 D42 D41 D40 Address: 000015<sub>H</sub> Port 5 direction register (DDR5) D57 D56 D55 D54 D53 D52 D51 D50 Address: 000016<sub>H</sub> Port 6 direction register (DDR6) Address: 000018<sub>H</sub> Port 8 direction register (DDR8) D85 D84 D83 D82 D80 Address: 00001A<sub>H</sub> SIL1 SIL0 Port A direction register (DDRA) Bit No. Address: 00001E<sub>H</sub> Port 2 pull-up control register (PUCR2) PU27 PU26 PU25 PU24 PU23 PU22 PU21 PU20 Bit No. 11/3 10/2 Address: 00000B<sub>H</sub> Port 5 analog input enable register (ADER5) ADE15 ADE14 ADE13 ADE12 ADE11 ADE10 ADE9 ADE8 Address: 00000CH Port 6 analog input enable register (ADER6) Bit No. 14/6 13/5 12/4 10/2 11/3 8/0 Address: 00000E<sub>H</sub> Input level select register (ILSR0) IL6 IL5 IL4 IL2 Address: 00000F<sub>H</sub> Input level select register (ILSR1) IL8

## 10.2.1 Port Data Register (PDR)

Note that R/W for I/O ports differ from R/W for memory in the following points:

Input mode

Read: The level at the corresponding pin is read.

Write: Data is written to an output latch.

Output mode

Read: The port data register latch value is read.

Write: Data is written to an output latch and outputted to the corresponding pin.

Figure 10.2-2 shows the port data registers (PDR).

## ■ Port Data Register (PDR)

Figure 10.2-2 Port Data Registers (PDR)



## Reading the port data register

The value obtained when reading the port data register (PDR) depends on the status of the port direction register (DDR) and status of the peripheral function connected to the pin.

The following shows the value obtained by each combination.

| Value of DDR | Output state of peripheral function | Reading value                         |
|--------------|-------------------------------------|---------------------------------------|
| 0 (input)    | Enabled                             | Output value from peripheral function |
| 1 (output)   | Enabled                             | Output value from peripheral function |
| 0 (input)    | Disabled                            | Pin state                             |
| 1 (output)   | Disabled                            | Value of output latch                 |

Further, when using as input by peripheral function, set the DDR of the connected pin to "0" (input).

## 10.2.2 Port Direction Register (DDR)

## This register has following functions:

- Setting the data direction of each pin that is used as a port.
- Setting the input level of SIN -- Serial data input pin for LIN-UART.

## ■ Port Direction Register (DDR)

Figure 10.2-3 shows the Port Direction Registers (DDR).

Reset value Access Bit No. 7 2 0 6 5 3 4 DDR2 D27 D26 D25 D24 D23 D22 D21 D20 0000000В R/W Address: 000012<sub>H</sub> Bit No. 7 6 4 2 0 1 DDR4 D44 D43 D42 D41 D40 XXX00000B Address: 000014<sub>H</sub> R/W Bit No. 7 6 5 DDR5 D57 D56 D55 D54 D53 D52 D51 D50 0000000В R/W Address: 000015<sub>H</sub> Bit No. 7 6 5 4 3 2 0 DDR6 D67 D66 D65 D64 D63 D62 D61 D60 0000000В R/W Address: 000016<sub>H</sub> Bit No. 7 6 3 2 0 DDR8 D87 D86 D85 D84 D83 D82 D80 000000X0B R/W Address: 000018<sub>H</sub> Bit No. 4 3 **DDRA** Access Address: 00001A<sub>H</sub> SIL1 SIL0 XXX00XXXB W W

Figure 10.2-3 Port Direction Registers (DDR)

## Bits Dxx (DDR2, DDR4 to DDR6, DDR8)

These bits set to the I/O direction of the port. When each pin is used as port, the corresponding pin is controlled below.

When set to "0": The corresponding pin is set to input mode.

When set to "1": The corresponding pin is set to output mode.

#### Bits SIL0, SIL1 (DDRA bit3, bit4)

These bits set the input level of the corresponding SIN (Serial Data Input for LIN-UART) pin forcibly. SIL0 to SIL1 correspond to SIN0 (LIN-UART0) to SIN1(LIN-UART1), respectively.

When setting to "0": CMOS or Automotive is selected for the input level depending on the setting of the corresponding ILx bit and ILTx bit in the ILSR. (See "10.2.5 Input Level Select Register" for ILSR.)

When set to "1": CMOS is selected for the input level regardless of the setting of the corresponding ILx bit and ILTx bit in ILSR.

The initial value of these bits is "0".

Table 10.2-1 SIN0/SIN1 Input Level Setting

| DDRA          | ILSR    | SIN0(P82) / SIN1(P85) |
|---------------|---------|-----------------------|
| SIL0/SIL1 bit | IL8 bit | input level           |
| 0             | 0       | Automotive level      |
| 0             | 1       | CMOS level            |
| 1             | X       | CMOS level            |

#### Note:

SIL0, SIL1 are write-only, and "1" is always read from these bits. Therefore, instructions that perform a read-modify-write (RMW) operation such as the INC/DEC instruction, cannot be used at DDRA.

DDRA: Bits 0 to 2, Bits 5 to 7 (unused bits)

"1" is always read from these bits. Writing to these bits is no effect.

## 10.2.3 Pull-up Control Register (PUCR)

Each pin of port2 has programmable pull-up resistor. Each bit of this register controls corresponding pull-up resistor whether to be used or not.

Figure 10.2-4 shows the pull-up control register (PUCR), and Figure 10.2-5 is the block diagram.

## ■ Pull-up Control Register (PUCR)

Figure 10.2-4 Pull-up Control Register (PUCR)



## ■ Block Diagram of Pull-up Control Register (PUCR)

Figure 10.2-5 Block Diagram of Pull-up Control Register (PUCR)



In input mode, the pull-up resistor is controlled.

- 0: No pull-up resistor in input mode
- 1: Pull-up resistor in input mode

#### Note:

In output mode, this register has no meaning (no pull-up resistor).

The port direction register (DDR) determines the input-output mode.

In stop mode (SPL=1), the state with no pull-up resistor is entered (high impedance).

## 10.2.4 Analog Input Enable Register (ADER)

Figure 10.2-6 shows the analog input enable register.

## ■ Analog Input Enable Registers (ADER)

Figure 10.2-6 Analog Input Enable Registers (ADER6, ADER5)



Each bit of ADER6/ADER5 sets to enable/disable the analog input of each pin in the port 6 and port 5. ADER6 and ADER5 correspond to the port 6 and port 5, respectively.

When set to "0": The corresponding pin is set to disable the analog input. A pin set to disable the analog input can be used as I/O pin for peripheral function other than I/O port and A/D converter.

When set to "1": The corresponding pin is set to the analog input mode. A pin set to the analog input mode is the dedicated analog input pin for the A/D converter. The pin cannot be used as I/O pin of I/O port and other peripheral function.

#### Note:

When the analog input enable bit (ADEx) is set to "1", each pin of the port 6 and port 5 is the analog input pin for the A/D converter. Initial value of the ADEx bit is "1". Therefore, the corresponding pins cannot be used as I/O pin of peripheral function other than I/O port and A/D converter at the initial setting. When the pin is used as I/O pin of other peripheral function and I/O port, the ADEx bit is set to "0".

## 10.2.5 Input Level Select Register

The input level select register allows to switch from Automotive Hysteresis input levels to CMOS Hysteresis input levels.

## ■ Input Level Select Register (ILSR)

The input level select register ILSR is located on addresses 0E<sub>H</sub> and 0F<sub>H</sub>.

Figure 10.2-7 Input Level Select Register (ILSR)



## bit 2, bit 4 to bit6 and bit8:IL2, IL4 to IL6, IL8

These bits set the input level of the corresponding port. IL2, IL4 to IL6, IL8 correspond to the port 2, port 4 to port 6, port 8, respectively. Setting these bits to "0" selects the Automotive input level. Setting these bits to "1" selects the CMOS hysteresis input level. The initial value of these bits depends on the mode pin setting:

- For the flash memory mode, the initial value is "1" (TTL).
- For all other modes, the initial value is "0" (Automotive).

### bit 0, bit 1, bit 3, bit 7 and bit 9 to bit 15: undefined

Reading from these bits is undefined. Writing to these bits is no effect.

#### Note:

The threshold of the corresponding input pin varies immediately after the setting of the input level select register is changed.

Therefore, do not use the read value from the pin until 2 machine cycles are elapsed after the setting is changed.

When the setting is changed, be sure to disable the corresponding resource.

## ■ Initial value of ILSR

Initial value of each bit of ILSR is determined when external reset signal is released depending on the value of MD2, MD1, MD0 pin input, as shown in following table.

About detail of each mode, please see "CHAPTER 9 MEMORY ACCESS MODES".

Table 10.2-2 Relationship between Mode Pin and Initial Value of Input Level Select Register (ILSR)

| MD2 | MD1 | MD0 | Operation mode                    | Initial<br>value | Port input level  |  |  |  |
|-----|-----|-----|-----------------------------------|------------------|-------------------|--|--|--|
|     |     |     |                                   | ILx              | Port 2, 4 to 6, 8 |  |  |  |
| 0   | 0   | 0   |                                   |                  |                   |  |  |  |
| 0   | 0   | 1   |                                   | Reserved         |                   |  |  |  |
| 0   | 1   | 0   |                                   |                  |                   |  |  |  |
| 0   | 1   | 1   | Internal vector mode 0 Automotive |                  | Automotive        |  |  |  |
| 1   | 0   | 0   |                                   | Dagarra          | 1                 |  |  |  |
| 1   | 0   | 1   | Reserved                          |                  |                   |  |  |  |
| 1   | 1   | 0   | Flash serial write                | 0                | Automotive        |  |  |  |
| 1   | 1   | 1   | Flash memory                      | 1                | TTL               |  |  |  |

## CHAPTER 11

# TIMEBASE TIMER

This chapter explains the functions and operations of the timebase timer.

- 11.1 Overview of Timebase Timer
- 11.2 Block Diagram of Timebase Timer
- 11.3 Configuration of Timebase Timer
- 11.4 Interrupt of Timebase Timer
- 11.5 Explanation of Operations of Timebase Timer Functions
- 11.6 Precautions when Using Timebase Timer
- 11.7 Program Example of Timebase Timer

## 11.1 Overview of Timebase Timer

The timebase timer is an 18-bit free-run counter (timebase timer counter) that increments in synchronization with the main clock (half frequency of main oscillation clock).

- Four interval times can be selected and an interrupt request can be generated for each interval time.
- An operation clock is supplied to the oscillation stabilization wait time timer and other peripherals.

#### ■ Interval Timer Function

- When the timebase timer counter reaches the interval time set by the interval time select bits (TBTC: TBC1, TBC0), an overflow (carrying) occurs (TBTC: TBOF = 1) and an interrupt request is generated.
- When an interrupt is enabled when an overflow occurs (TBTC: TBIE = 1), an overflow occurs (TBTC: TBOF = 1) and an interrupt is generated.
- The timebase timer has four interval times that can be selected. Table 11.1-1 shows the interval times of the timebase timer.

Table 11.1-1 Interval Times of Timebase Timer

| Count clock    | Interval time                            |
|----------------|------------------------------------------|
| 2/HCLK(0.5 μs) | 2 <sup>12</sup> /HCLK (approx. 1.0 ms)   |
|                | 2 <sup>14</sup> /HCLK (approx. 4.1 ms)   |
|                | 2 <sup>16</sup> /HCLK (approx. 16.4 ms)  |
|                | 2 <sup>19</sup> /HCLK (approx. 131.1 ms) |

HCLK: Oscillation clock

The parenthesized values are provided at 4-MHz oscillation clock.

## **■** Clock Supply

The timebase timer supplies an operation clock to the resources such as an oscillation stabilization wait time timer, PPG timer, and watchdog timer. Table 11.1-2 shows the clock cycles supplied from the timebase timer to each resource.

Table 11.1-2 Clock Cycles Supplied from Timebase Timer

| Where to supply clock                | Clock cycle                              |
|--------------------------------------|------------------------------------------|
| Oscillation stabilization wait time* | 2 <sup>10</sup> /HCLK (approx. 256 μs)   |
|                                      | 2 <sup>13</sup> /HCLK (approx. 2.0 ms)   |
|                                      | 2 <sup>15</sup> /HCLK (approx. 8.2 ms)   |
|                                      | 2 <sup>17</sup> /HCLK (approx. 32.8 ms)  |
| Watchdog timer                       | 2 <sup>12</sup> /HCLK (approx. 1.0 ms)   |
|                                      | 2 <sup>14</sup> /HCLK (approx. 4.1 ms)   |
|                                      | 2 <sup>16</sup> /HCLK (approx. 16.4 ms)  |
|                                      | 2 <sup>19</sup> /HCLK (approx. 131.1 ms) |
| PPG timer                            | 2 <sup>9</sup> /HCLK (approx. 128 μs)    |

HCLK: Oscillation clock

The parenthesized values are provided at 4-MHz oscillation clock.

<sup>\*:</sup> As the oscillation cycle is unstable immediately after oscillation starts, standard oscillation stabilization wait time values are given as a guide.

## 11.2 Block Diagram of Timebase Timer

The timebase timer consists of the following blocks:

- Timebase timer counter
- Counter clear circuit
- Interval timer selector
- Timebase timer control register (TBTC)

## **■** Block Diagram of Timebase Timer



The actual interrupt request number of the timebase timer is as follows:

Interrupt request number: #25 (19<sub>H</sub>)

#### Timebase timer counter

The timebase timer counter is an 18-bit up counter that uses a clock with a half frequency of the oscillation clock (HCLK) as a count clock.

## Counter clear circuit

The counter clear circuit clears the value of the timebase timer counter by the following factors:

- Timebase timer counter clear bit in the timebase timer control register (TBTC: TBR=0)
- · Power-on reset
- Transition to main stop mode or PLL stop mode (CKSCR:SCS=1, LPMCR: STP=1)
- Switching the clock mode (from main clock mode to PLL clock mode, from subclock mode to PLL clock mode, or from subclock mode to main clock mode)

#### Interval timer selector

The interval timer selector selects the output of the timebase timer counter from four types.

When incrementing causes the selected interval time bit to overflow (carrying), an interrupt request is generated.

## Timebase timer control register (TBTC)

The timebase timer control register (TBTC) selects the interval time, clears the timebase timer counter, enables or disables interrupts, and checks and clears the state of an interrupt request.

## 11.3 Configuration of Timebase Timer

This section explains the registers and interrupt factors of the timebase timer.

## ■ List of Registers and Reset Values of Timebase Timer

Figure 11.3-1 List of Registers and Reset Values of Timebase Timer

Timebase timer control register (TBTC)

×: Undefined

## **■** Generation of Interrupt Request from Timebase Timer

When the selected interval timer counter bit reaches the interval time, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set to "1". If the overflow interrupt request flag bit is set (TBTC: TBOF = 1) when the interrupt is enabled (TBTC: TBIE = 1), the timebase timer generates an interrupt request.

## 11.3.1 Timebase timer control register (TBTC)

The timebase timer control register (TBTC) provides the following settings:

- · Selecting the interval time of the timebase timer
- · Clearing the counter value of the timebase timer
- Enabling or disabling the interrupt request when an overflow occurs
- Checking and clearing the state of the interrupt request flag when an overflow occurs

## **■** Timebase Timer Control Register (TBTC)



Table 11.3-1 Functions of Timebase Timer Control Register (TBTC)

| Bit name       |                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15          | Reserved: reserved bit                          | Always set this bit to "1".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit14<br>bit13 | Undefined bits                                  | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bit12          | TBIE:<br>Overflow interrupt<br>enable bit       | This bit enables or disables an interrupt when the interval timer bit in the timebase timer counter overflows.  When set to "0": No interrupt request is generated at an overflow (TBOF = 1).  When set to "1": An interrupt request is generated at an overflow (TBOF = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| bit11          | TBOF:<br>Overflow interrupt<br>request flag bit | This bit indicates an overflow (carrying) in the interval timer bit in the timebase timer counter.  When an overflow (carrying) occurs (TBOF = 1) with interrupts enabled (TBIE = 1), an interrupt request is generated.  When set to "0": The bit is cleared.  When set to "1": Disabled. The state remains unchanged.  Read by read modify write instructions: "1" is read.  Note:  1) To clear the TBOF bit, disable interrupts (TBIE = 0) or mask interrupts using the interrupt mask register (ILM) in the processor status.  2) The TBOF bit is cleared at a write of "0", transition to main stop mode or to PLL stop mode, transition from subclock mode to main clock mode or to PLL clock mode, transition from main clock mode to PLL clock mode, at a write of "0" to the timebase timer counter clear bit (TBR), or at a reset. |
| bit10          | TBR:<br>Timebase timer<br>counter clear bit     | This bit clears all the bits in the timebase timer counter.  When set to "0": All the bits in the timebase timer counter are cleared to "0". The TBOF bit is also cleared.  When set to "1": Disabled. The state remains unchanged.  Read: "1" is always read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bit9<br>bit8   | TBC1, TBC0:<br>Interval time select<br>bits     | These bits set the cycle of the interval timer in the timebase timer counter.  • The interval time of the timebase timer is set according to the setting of the TBC1 and TBC0 bits.  • One of four time intervals can be selected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## 11.4 Interrupt of Timebase Timer

The timebase timer generates an interrupt request (interval timer function) when the interval time bit in the timebase timer counter corresponding to the interval time set by the timebase timer control register carries (overflows).

## ■ Interrupt of Timebase Timer

- The timebase timer continues incrementing for as long as the main clock (with a half frequency of the oscillation clock) is inputted.
- When the interval time set by the interval time select bits in the timebase timer control register (TBTC: TBC1, TBC0) is reached, the interval time select bit corresponding to the interval time selected in the timebase timer counter carries and an overflow generates.
- When the interval time select bit overflows, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set to "1".
- When the overflow interrupt request flag bit in the timebase timer control register is set (TBTC: TBOF = 1) with an interrupt enabled (TBTC: TBIE = 1), an interrupt request is generated.
- When the selected interval time is reached, the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF) is set regardless of whether an interrupt is enabled or disabled (TBTC: TBIE)
- To clear the overflow interrupt request flag bit (TBTC: TBOF), disable a timebase timer interrupt at interrupt processing (TBTC: TBIE = 0) or mask a timebase timer interrupt by using the ILM bit in the processor status (PS) to write "0" to the TBOF bit.

#### Note:

An interrupt request is issued immediately if you enable interrupts (TBTC: TBIE = 1) with the overflow interrupt request flag bit in the timebase timer control register set (TBTC: TBOF = 1).

## ■ Correspondence between Timebase Timer Interrupt and El<sup>2</sup>OS

- The timebase timer does not correspond to EI<sup>2</sup>OS.
- For details of the interrupt number, interrupt control register, and interrupt vector address, see "3.2 Interrupt Vector".

## 11.5 Explanation of Operations of Timebase Timer Functions

The timebase timer operates as an interval timer or an oscillation stabilization wait time timer. It also supplies a clock to peripherals.

#### ■ Interval Timer Function

Interrupt generation at every interval time enables the timebase timer to be used as an interval timer.

Operating the timebase timer as an interval timer requires the settings shown in Figure 11.5-1.

## Setting of timebase timer

Figure 11.5-1 Setting of Timebase Timer

## Operations of the Interval Timer Functions

The timebase timer can be used as an interval timer by generating an interrupt at every set interval time.

- The timebase timer continues incrementing in synchronization with the main clock (a half frequency of the oscillation clock) while the oscillation clock is active.
- When the timebase timer counter reaches the interval time set by the interval time select bits in the timebase timer control register (TBTC: TBC1, TBC0), it causes an overflow (carrying) and the overflow interrupt request flag bit (TBTC: TBOF) is set to "1".
- When the overflow interrupt request flag bit is set (TBTC: TBOF = 1) with interrupts enabled (TBTC: TBIE = 1), an interrupt request is generated.

#### Note:

1 : Set to "1".

The interval time may be longer than the one set by clearing the timebase timer counter.

## Example of operation for timebase timer

Figure 11.5-2 gives an example of the operation that the timebase timer performs under the following conditions:

- A power-on reset occurs.
- The mode transits to the sleep mode during the operation of the interval timer.
- The mode transits to the stop mode during the operation of the interval timer.
- A request to clear the timebase timer counter is issued.

At transition to the stop mode, the timebase timer counter is cleared to stop counting up. At return from the stop mode, the timebase timer counts the oscillation stabilization wait time of the main clock.



Figure 11.5-2 Example of Operation for Timebase Timer

## ■ Operation as Oscillation Stabilization Wait Time Timer

The timebase timer can be used as the oscillation stabilization wait time timer for the main clock and PLL clock.

The oscillation stabilization wait time is the time elapsed from when the timebase timer counter increments from "0" until the set oscillation stabilization wait time select bit overflows (carrying).

Table 11.5-1 shows clearing conditions and oscillation stabilization wait time of timebase timer.

Table 11.5-1 Clearing Conditions and Oscillation Stabilization Wait Time of Timebase Timer (1/2)

| Operation                                                                                       | Counter<br>clear | TBOF<br>clear | Oscillation stabilization wait time                                                             |
|-------------------------------------------------------------------------------------------------|------------------|---------------|-------------------------------------------------------------------------------------------------|
| Writing "0" to timebase timer counter clear bit (TBTC: TBR)                                     | 0                | 0             |                                                                                                 |
| Reset                                                                                           |                  |               |                                                                                                 |
| Power-on reset                                                                                  | О                | 0             | Transition to main clock mode after oscillation stabilization wait time of main clock completed |
| Watchdog reset                                                                                  | ×                | 0             | None                                                                                            |
| External reset Low voltage detection reset CPU operation detection reset Clock supervisor reset | X                | 0             | None                                                                                            |
| Software reset                                                                                  | ×                | 0             | None                                                                                            |
| Switching clock mode                                                                            |                  |               |                                                                                                 |
| Main clock $\rightarrow$ PLL clock (CKSCR: MCS=1 $\rightarrow$ 0)                               | О                | 0             | Transition to PLL clock mode after oscillation stabilization wait time of PLL clock completed   |
| Main clock $\rightarrow$ sub clock (CKSCR: SCS=1 $\rightarrow$ 0)                               | ×                | ×             | Transition to sub clock mode after oscillation stabilization wait time of sub clock completed   |
| Sub clock $\rightarrow$ main clock (CKSCR: SCS=0 $\rightarrow$ 1)                               | 0                | 0             | Transition to main clock mode after oscillation stabilization wait time of main clock completed |
| Sub clock $\rightarrow$ PLL clock (CKSCR: MCS=0, SCS=0 $\rightarrow$ 1)                         | 0                | 0             | Transition to PLL clock mode after oscillation stabilization wait time of main clock completed  |
| PLL clock $\rightarrow$ main clock<br>(CKSCR: MCS=0 $\rightarrow$ 1)                            | ×                | ×             | None                                                                                            |
| PLL clock $\rightarrow$ sub clock<br>(CKSCR: MCS=0, SCS=1 $\rightarrow$ 0)                      | ×                | ×             | None                                                                                            |

Table 11.5-1 Clearing Conditions and Oscillation Stabilization Wait Time of Timebase Timer (2/2)

| Operation                            | Counter<br>clear           | TBOF<br>clear | Oscillation stabilization wait time                                                             |  |  |  |  |
|--------------------------------------|----------------------------|---------------|-------------------------------------------------------------------------------------------------|--|--|--|--|
| Cancellation of stop modes           | Cancellation of stop modes |               |                                                                                                 |  |  |  |  |
| Cancellation of main stop mode       | О                          | О             | Transition to main clock mode after oscillation stabilization wait time of main clock completed |  |  |  |  |
| Cancellation of PLL stop mode        | О                          | О             | Transition to PLL clock mode after oscillation stabilization wait time of main clock completed  |  |  |  |  |
| Cancellation of sub-stop mode        | ×                          | ×             | Transition to sub clock mode after oscillation stabilization wait time of sub clock completed   |  |  |  |  |
| Cancellation of watch mode           |                            |               |                                                                                                 |  |  |  |  |
| Cancellation of sub-watch mode       | X                          | x             | None                                                                                            |  |  |  |  |
| Cancellation of timebase timer modes |                            |               |                                                                                                 |  |  |  |  |
| Return to main clock mode            | X                          | ×             | None                                                                                            |  |  |  |  |
| Return to sub clock mode             | x                          | x             | None                                                                                            |  |  |  |  |
| Return to PLL clock mode             | X                          | ×             | None                                                                                            |  |  |  |  |
| Cancellation of sleep modes          |                            |               |                                                                                                 |  |  |  |  |
| Cancellation of main sleep mode      | ×                          | ×             | None                                                                                            |  |  |  |  |
| Cancellation of sub-sleep mode       | ×                          | ×             | None                                                                                            |  |  |  |  |
| Cancellation of PLL sleep mode       | ×                          | X             | None                                                                                            |  |  |  |  |

## ■ Supply of Operation Clock

The timebase timer supplies an operation clock to the PPG timers and the watchdog timer.

#### Note:

Clearing the timebase timer counter may affect the operation of the resources such as the watchdog timer and PPG timers using the output of the timebase timer.

#### References:

- For details on the PPG timer, see "CHAPTER 16 8-/16-BIT PPG TIMER".
- For details on the watchdog timer, see "CHAPTER 12 WATCHDOG TIMER".

## 11.6 Precautions when Using Timebase Timer

## Precautions when using the timebase timer are shown below.

## **■** Precautions when Using Timebase Timer

## Clearing interrupt request

To clear the overflow interrupt request flag bit in the timebase timer control register (TBTC: TBOF = 0), disable interrupts (TBTC: TBIE = 0) or mask the timebase timer interrupt by using the interrupt level mask register in the processor status.

#### Clearing timebase timer counter

Clearing the timebase timer counter affects the following operations:

- When the timebase timer is used as the interval timer (interval interrupt).
- When the watchdog timer is used.
- When the clock supplied from the timebase timer is used as the operation clock of the PPG timer.

## Using timebase timer as oscillation stabilization wait time timer

After power on or in the main stop mode, PLL stop mode, and sub clock mode, the oscillation clock stops. Therefore, when oscillation starts, the timebase timer requires the oscillation stabilization wait time of the main clock. An appropriate oscillation stabilization wait time must be selected according to the types of oscillators connected to high-speed oscillation input pins.

#### **Reference:**

For details on the oscillation stabilization wait time, see "5.6 Oscillation Stabilization Wait Interval".

## Resources to which timebase timer supplies clock

- At transition to operation modes (PLL stop mode, sub clock mode, and main stop mode) in which the oscillation clock stops, the timebase timer counter is cleared and the timebase timer stops.
- When the timebase timer counter is cleared, an after-clearing interval time is needed. It may cause the clock supplied from the timebase timer to have a short High level or a 1/2 cycle longer Low level.
- The watchdog timer performs normal counting because the watchdog timer counter and timebase timer counter are cleared simultaneously.

## 11.7 Program Example of Timebase Timer

## Programming examples for the timebase timer are shown below.

## ■ Program Example of Timebase Timer

Processing specification

The  $2^{12}$ /HCLK (HCLK: oscillation clock) interval interrupt is generated repeatedly. In this case, the interval time is approximately 1.0 ms (at 4-MHz operation).

## Coding example

```
ICR07
        EQU
               0000B7H
                               ; Timebase timer interrupt control register
               0000A9H
                               ;Timebase timer control register
TBTC
        EQU
TBOF
        EQU
               TBTC:3
                               ; Interrupt request flag bit
        EQU
                               ; Interrupt enable bit
TBIE
               TBTC:2
;-----Main program-----
CODE
        CSEG
START:
                               ;Stack pointer(SP), already initialized
        AND
                CCR, #0BFH
                               ;Interrupt disable
        MOV
                I:ICR07 #00H
                               ;Interrupt level 0(highest)
                I:TBTC,#1000000B
        MOV
                               ;Upper 3 bis are fixed
                               ;TBOF clear,
                               ;Counter clear interval time
                               ;2<sup>12</sup>/HCLK selection
        SETB
                I:TBIE
                               ; Interrupt enable
        MOV
                ILM, #07H
                               ;Setting ILM in PS to level 7
        OR
                CCR, #40H
                               ;Interrupt enable
LOOP:
        VOM
               A,#00H
                               ; No limit loop
        MOV
                A, #01H
        BRA
                LOOP
;-----Interrupt program------
WARI:
        CLRB
                               ;Clear interrupt enable bit
                I:TBIE
        CLRB
                               ;Clear interrupt request flag
                I:TBOF
      User processing
        SETB
                I:TBIE
                               ;Interrupt enable
        RETI
                               ; Recovery from interrupt processing
CODE
        ENDS
;-----Vector setting------
                ABS=0FFH
VECT
        CSEG
        ORG
                               ; Vector setting to interrupt number
                0FF98H
                                #25(19_{H})
```

## CHAPTER 11 TIMEBASE TIMER

|      | DSL  | WARI   |                              |
|------|------|--------|------------------------------|
|      | ORG  | 0FFDCH | ;Reset vector setting        |
|      | DSL  | START  |                              |
|      | DB   | 00H    | ;Setting to single-chip mode |
| VECT | ENDS |        |                              |
|      | END  | START  |                              |

# CHAPTER 12

# **WATCHDOG TIMER**

This chapter describes the function and operation of the watchdog timer.

- 12.1 Overview of Watchdog Timer
- 12.2 Configuration of Watchdog Timer
- 12.3 Watchdog Timer Registers
- 12.4 Explanation of Operations of Watchdog Timer Functions
- 12.5 Precautions when Using Watchdog Timer
- 12.6 Program Examples of Watchdog Timer

## 12.1 Overview of Watchdog Timer

The watchdog timer is a 2-bit counter that uses the timebase timer or watch timer as a count clock. If the counter is not cleared within a set interval time, the CPU is reset.

## **■** Functions of Watchdog Timer

- The watchdog timer is a timer counter that is used to prevent program malfunction. When the watchdog timer is started, the watchdog timer counter must continue to be cleared within a set interval time. If the set interval time is reached without clearing the watchdog timer counter, the CPU is reset. This is called watchdog timer.
- The interval time of the watchdog timer depends on the clock cycle input as a count clock and a watchdog reset occurs between the minimum and maximum times.
- The clock source output destination is set by the watchdog clock select bit in the watch timer control register (WTC: WDCS).
- The interval time of the watchdog timer is set by the timebase timer output select bit/watch timer output select bit in the watchdog timer control register (WDTC: WT1, WT0).

Table 12.1-1 lists the interval times of the watchdog timer.

Table 12.1-1 Interval Time of Watchdog Timer

Main

| Clock cycle                       | Examples calculated   |           |                   |                  |  |
|-----------------------------------|-----------------------|-----------|-------------------|------------------|--|
|                                   | External clock(@4MHz) |           | CR oscillation    |                  |  |
|                                   | Min. Max.             |           | Min.<br>(@200kHz) | Max.<br>(@50kHz) |  |
| 2 <sup>14</sup> ± 2 <sup>11</sup> | Approx.               | Approx.   | Approx.           | Approx. 0.369 s  |  |
| /HCLK                             | 3.58 ms               | 4.61 ms   | 0.072 s           |                  |  |
| 2 <sup>16</sup> ±2 <sup>13</sup>  | Approx.               | Approx.   | Approx.           | Approx.          |  |
| /HCLK                             | 14.33 ms              | 18.4 ms   | 0.287 s           | 1.475 s          |  |
| 2 <sup>18</sup> ±2 <sup>15</sup>  | Approx.               | Approx.   | Approx.           | Approx.          |  |
| /HCLK                             | 57.34 ms              | 73.73 ms  | 1.147 s           | 5.898 s          |  |
| 2 <sup>21</sup> ± 2 <sup>18</sup> | Approx.               | Approx.   | Approx.           | Approx. 47.186 s |  |
| /HCLK                             | 458.75 ms             | 589.82 ms | 9.175 s           |                  |  |

Sub

| Clock cycle                       | Examples calculated                           |          |                   |                  |
|-----------------------------------|-----------------------------------------------|----------|-------------------|------------------|
|                                   | External clock (@32kHz, 4-frequency division) |          | CR oscillation    |                  |
|                                   | Min.                                          | Max.     | Min.<br>(@200kHz) | Max.<br>(@50kHz) |
| 2 <sup>12</sup> ± 2 <sup>9</sup>  | Approx.                                       | Approx.  | Approx.           | Approx. 0.092 s  |
| /SCLK                             | 0.437 s                                       | 0.563 s  | 0.018 s           |                  |
| 2 <sup>15</sup> ± 2 <sup>12</sup> | Approx.                                       | Approx.  | Approx.           | Approx. 0.737 s  |
| /SCLK                             | 3.500 s                                       | 4.500 s  | 0.143 s           |                  |
| 2 <sup>16</sup> ±2 <sup>13</sup>  | Approx.                                       | Approx.  | Approx.           | Approx. 1.475 s  |
| /SCLK                             | 7.000 s                                       | 9.000 s  | 0.287 s           |                  |
| 2 <sup>17</sup> ±2 <sup>14</sup>  | Approx.                                       | Approx.  | Approx.           | Approx.          |
| /SCLK                             | 14.000 s                                      | 18.000 s | 0.573 s           | 2.949 s          |

Note: See "CHAPTER 6 CLOCK SUPERVISOR" for the CR oscillation.

#### **Notes:**

- When the timebase timer output (carry signal) is used as a count clock to the watchdog timer, clearing the timebase timer may extend the time for a watchdog reset to occur.
- When the subclock is used as the machine cock, be sure to set the watchdog timer clock source select bit (WDCS) in the watch timer control register (WTC) to "0" to select the watch timer output.

## 12.2 Configuration of Watchdog Timer

The watchdog timer consists of the following blocks:

- Count clock selector
- Watchdog timer counter (2-bit counter)
- · Watchdog reset generator
- Counter clear control circuit
- Watchdog timer control register (WDTC)

## ■ Block Diagram of Watchdog Timer

Figure 12.2-1 Block Diagram of Watchdog Timer Watchdog timer control register (WDTC) Watch timer control register (WTC) WRSTERSTSRSTWTE WT1 PONR WDCS Watchdog timer Start up Generation of reset Count clock To internal Counter Watchdog reset Shift to sleep mode 2-bit selector generation reset clear control Shift to timebase counter generation timer mode circuit circuit Shift to watch mode circuit Clear Shift to stop mode (Timebase timer counter) Main clock  $\times 2^8$ (2 division of HCLK) (Watch counter) Sub clock  $\times 2^6$  $\times 2^8$  $\times 2^9$  $\times 2^7$ SCLK\* HCLK: Oscillation clock SCLK: Sub clock \*: SCLK is 2 division or 4 division of the clock inputted to the low-speed oscillation pin (X0A and X1A) or internal CR oscillation clock. The division ratio is set by the SCDS bit of the PLL/subclock control register (PSCCR). (See "CHAPTER 5 CLOCKS".)

## CHAPTER 12 WATCHDOG TIMER

#### Count clock selector

The count clock selector selects a count clock input to the watchdog timer from the timebase timer or watch timer. Each timer output has four time intervals that can be set.

## Watchdog timer counter (2-bit counter)

The watchdog timer counter is a 2-bit counter that uses the timebase timer output or watch timer output as a count clock. The clock source output destination is set by the watchdog clock select bit in the watch timer control register (WTC: WDCS).

## Watchdog reset generator

The watchdog reset generation circuit generates a reset signal when the watchdog timer overflows (carrying).

## Counter clear circuit

The counter clear circuit clears the watchdog timer counter.

## Watchdog timer control register (WDTC)

The watchdog timer control register starts and clears the watchdog timer, sets the interval time, and holds reset factors.

# 12.3 Watchdog Timer Registers

This section explains the registers used for setting the watchdog timer.

### ■ List of Registers and Reset Values of Watchdog Timer

Figure 12.3-1 List of Registers and Reset Values of Watchdog Timer

|                                        | bit                            | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
|----------------------------------------|--------------------------------|---|---|---|---|---|---|---|---|
| Watchdog timer control register (WDTC) | Address<br>0000A8 <sub>H</sub> | × | × | × | × | × | 1 | 1 | 1 |

### 12.3.1 Watchdog timer control register (WDTC)

The watchdog timer control register starts and clears the watchdog timer, sets the interval time, and holds reset factors.

#### ■ Watchdog Timer Control Register (WDTC)

Figure 12.3-2 Watchdog Timer Control Register (WDTC)



X1A) or internal CR oscillation clock. The division ratio is set by the SCDS bit of the PLL/subclock control

register (PSCCR). (See "CHAPTER 5 CLOCKS".)

See Table 12.1-1 for the interval time.

**Table 12.3-1 Functions of the Watching Timer Control Register (WDTC)** 

|                             | Bit name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-----------------------------|-------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit0<br>bit1                | WT1, WT0:<br>Interval time select<br>bits       | These bits set the interval time of the watchdog timer. The time interval when the watch timer is used as the clock source to the watchdog timer (watchdog clock select bit WDCS=0) is different from when the main clock mode or the PLL clock mode is selected as the clock mode and the WDCS bit in the watch timer control register (WTC) is set to "1" as shown in Figure 12.3-2 according to the settings of the WTC register.  In the subclock mode, be sure to set the watchdog clock select bit (WDCS) in the watch timer control register (WTC) to "0" and select the output of the watch timer.  • Data after the watchdog timer is started is valid only.  • Write data after the watchdog timer is started is ignored.  • These are write-only bits. |  |
| bit2                        | WTE:<br>Watchdog timer<br>control bit           | This bit starts or clears the watchdog timer.  When set to "0" (first time after reset): The watchdog timer is started.  When set to "0" (second or subsequent): The watchdog timer is cleared.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| bit6                        | Undefined bit                                   | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| bit3<br>to<br>bit5,<br>bit7 | PONR, WRST, ERST,<br>SRST:<br>Reset factor bits | <ul> <li>These bits indicate reset factors.</li> <li>When a reset occurs, the bit corresponding to the reset factor is set to "1". After a reset, the reset factor can be checked by reading the watchdog timer control register (WDTC).</li> <li>These bits are cleared after the watchdog timer control register (WDTC) is read.</li> <li>Note: No bit value other than the PONR bit after power-on reset is assured. If the PONR bit is set at read, other bit values should be ignored.</li> </ul>                                                                                                                                                                                                                                                            |  |

# 12.4 Explanation of Operations of Watchdog Timer Functions

After starting, when the watchdog timer reaches the set interval time without the counter being cleared, a watchdog reset occurs.

#### ■ Operations of Watchdog Timer

The operation of the watchdog timer requires the settings shown in Figure 12.4-1.

Figure 12.4-1 Setting of Watchdog Timer



#### Selecting clock input source

- The timebase timer or watch timer can be selected as the clock input source of the count clock to the watchdog timer. When the watchdog clock select bit (WTC: WDCS) is set to "1", the timebase timer is selected. When the bit is set to 0, the watch timer is selected. After a reset, the bit returns to "1".
- During operation in the sub clock mode, set the WDCS bit to 0 to select the watch timer.

#### Setting interval time

- Set the interval time select bits (WDTS: WT1, WT0) to select the interval time for the watchdog timer.
- Set the interval time concurrently when starting the watchdog timer. Writing to the bit is ignored after the watchdog timer is started.

#### Activating watchdog timer

When "0" is written to the watchdog timer control bit (WDTC: WTE) after a reset, the watchdog timer is started and starts incrementing.

#### Clearing watchdog timer

- When "0" is written once again to the watchdog timer control bit (WDTC: WTE) within the interval time after starting the watchdog timer, the watchdog timer is cleared. If the watchdog timer is not cleared within the interval time, it overflows and the CPU is reset.
- A reset, or transitions to the standby modes (sleep mode, stop mode, watch mode, timebase timer mode) clear the watchdog timer.
- During operation in the timebase timer mode or watch mode, the watchdog timer counter is cleared. However, the watchdog timer remains in the activation state.
- Figure 12.4-2 shows relationship between clear timing and interval time of watchdog timer. The interval time varies with the timing of clearing the watchdog timer.

#### Checking reset factors

The reset factor bits in the watchdog timer control register (WDTC: PONR, WRST, ERST, SRST) can be read after a reset to check the reset factors.

Reference:

For details on the reset factor bit, see "CHAPTER 7 RESETS".

Figure 12.4-2 Relationship between Clear Timing and Interval Time of Watchdog Timer [Watchdog timer block diagram] 2-bit counter Clock 2-division 2-division Reset Reset selector circuit circuit circuit signal Count enable and clear Count enable WTE bit output circuit [Minimum interval time] When clear WTE bit immediately before rising of count clock. Count start Counter clear Count clock a 2-division's value b 2-division's value c Count enable Reset signal d 7 × (Count clock cycle/2) Watchdog reset generation WTE bit clear [Maximum interval time] When clear WTE bit immediately after rising of count clock. Count start Counter clear Count clock a 2-division's value b 2-division's value c Count enable Reset signal 9 × (Count clock cycle/2) Watchdog reset generation WTE bit clear

### 12.5 Precautions when Using Watchdog Timer

#### Take the following precautions when using the watchdog timer.

#### ■ Precautions when Using Watchdog Timer

#### Stopping watchdog timer

The watchdog timer is stopped by all the reset sources.

#### Interval time

- The interval time uses the carry signal of the timebase timer or watch timer as a count clock. If the timebase timer or watch timer is cleared, the interval time of the watchdog timer may become long. Note that the timebase timer is cleared when "0" is written to the timebase timer counter clear bit (TBR) in the timebase timer control register (TBTC) and when the clock mode changes from the main clock to PLL clock, from the subclock to main clock, or from the subclock to PLL clock.
- Set the interval time concurrently when starting the watchdog timer. Setting the time interval except starting the watchdog timer is ignored.

#### Precautions when creating program

When clearing the watchdog timer repeatedly in the main loop, set a shorter processing time for the main loop, including interrupt processing, than the interval time of watchdog timer.

#### Precautions in subclock mode

In the subclock mode, be sure to set the watchdog clock select bit (WDCS) in the watch timer control register (WTC) to "0" and select the output of the watch timer.

# 12.6 Program Examples of Watchdog Timer

#### Program example of watchdog timer is given below:

#### ■ Program Examples of Watchdog Timer

- Processing specification
  - The watchdog timer is cleared each time in the loop of the main program.
  - The main program must be executed once within the minimum interval time of the watchdog timer.

#### Coding example

```
WDTC
      EOU
           H8A0000
                             ; Watchdog timer control
                              register
                             ; Watchdog control bit
WTE
      EQU
           WDTC:2
;-----Main program------
           CSEG
START:
                             ;Stack pointer (SP), already
                             ;initialized
      VOM
           I:WDTC, #00000011B ;Start up of watchdog timer
                             ; Select interval time 2^{21}+2^{18}
                             ;cycle
LOOP:
      CLRB I:WTE
                             ;Clear watchdog timer
      ÅE
      User processing
      ÅE
      BRA
           LOOP
;------Vector setting------
VECT
      CSEG ABS=0FFH
      ORG
           00FFDCH
                             ; Reset vector setting
      DSL
           START
      DB
           00H
                             ;Setting to single chip mode
VECT
      ENDS
      END
           START
```

# **CHAPTER 13**

# 16-Bit I/O TIMER

This chapter explains the function and operation of the 16- bit I/O timer.

- 13.1 Overview of 16-bit I/O Timer
- 13.2 Block Diagram of 16-bit I/O Timer
- 13.3 Configuration of 16-bit I/O Timer
- 13.4 Interrupts of 16-bit I/O Timer
- 13.5 Explanation of Operation of 16-bit Free-run Timer
- 13.6 Explanation of Operation of Input Capture
- 13.7 Precautions when Using 16-bit I/O Timer
- 13.8 Program Example of 16-bit I/O Timer

#### 13.1 Overview of 16-bit I/O Timer

The 16-bit I/O timer consists of one 16-bit free-run timer and 4 input capture. The timer can be performed the measurement of input pulse and external clock cycle based on the 16-bit free-run timer.

#### ■ Module Configuration of 16-bit I/O Timer

The 16-bit I/O timer consists of the following modules:

• 16-bit free-run timer × 1 unit

16-bit free-run timer 0 (channel 0)

• Input capture × 4 units

Input capture unit 0: capture 16-bit free-run timer 0

- Input capture 0 (channel 0)
- Input capture 1 (channel 1)
- Input capture 2 (channel 2)
- Input capture 3 (channel 3)

#### ■ Functions of 16-bit I/O Timer

#### Functions of 16-bit free-run timer

The 16-bit free-run timer consists of a 16-bit up counter, a prescaler, and a control register.

The count value of the 16-bit free-run timer can be use as the base time for the input capture.

- One of eight types of the count clock cycle can be set.
- An overflow in the counter generates an interrupt request.
- The counter of the 16-bit free-run timer is cleared to " $0000_{
  m H}$ " by reset or timer clear (TCCSL:CLR=1).

#### Functions of input capture

The input capture consists of four 16-bit capture registers and control registers corresponding to the external input pin, and the edge detection circuit.

When the trigger edge is inputted to the external input pin, the counter value of the 16-bit free-run timer is retained and the interrupt request is generated at the same time.

- The capture interrupt can be generated independently by each channel.
- The EI<sup>2</sup>OS can be started.
- Trigger edge can be selected from rising edge, falling edge, or both edges.
- Because each channel operates independently, up to 4 input measurement is performed.
- When the input signal is set to the LIN-UART, the baud rate measurement at LIN slave operation is executed.

# 13.2 Block Diagram of 16-bit I/O Timer

The 16-bit I/O timer consists of the following modules:

- 16-bit free-run timer
- Input capture

#### ■ Block Diagram of 16-bit I/O Timer

Internal data bus

Input capture

Dedicated bus free-run timer

Figure 13.2-1 Block Diagram of 16-bit I/O Timer

#### ● 16-bit free-run timer

The count value of the 16-bit free-run timer can be used as the base time for the input capture.

#### Input capture

When the trigger edge is inputted to the external input pin, or when the trigger edge for the LIN slave baud rate measurement from the LIN-UART is inputted, the counter value of the 16-bit free-run timer is retained and the interrupt request is generated at the same time.

# ■ Details of Pins and Interrupt Number

Table 13.2-1 shows the pins used by the 16-bit details of interrupt.

Table 13.2-1 Details of Pins and Interrupt Number

| Channel                                             | Special terminal | Pin name  | Interrupt<br>No.          | For<br>I <sup>2</sup> OS |
|-----------------------------------------------------|------------------|-----------|---------------------------|--------------------------|
| Input capture ch0 (using 16-bit free-run timer ch0) | IN0              | P24/IN0   | #33                       |                          |
| Input capture ch1 (using 16-bit free-run timer ch0) | IN1              | P25/IN1   | (21 <sub>H</sub> )        |                          |
| Input capture ch2 (using 16-bit free-run timer ch0) | IN2              | P26/IN2   |                           |                          |
| Input capture ch3 (using 16-bit free-run timer ch0) | IN3              | P27/IN3   |                           |                          |
| 16-bit free-run timer ch0 (overflow interrupt)      | FRCK0            | P44/FRCK0 | #30<br>(1E <sub>H</sub> ) | ×                        |

#### **Block Diagram of 16-bit Free-run Timer** 13.2.1

The MB90360 series contains 1 channel of the 16-bit free-run timer, and it consists of the following block.

#### ■ Block Diagram of 16-bit Free-run Timer



Figure 13.2-2 Block Diagram of 16-bit Free-run Timer

#### Prescaler

The prescaler divides the frequency of the machine clock to supply a count clock to the 16-bit counter. Any of eight count clock cycles can be selected by setting the timer control status register (TCCSL: CLK2 to CLK0).

#### Timer data register (TCDT)

The timer data register can read the counter value of the 16-bit free-run timer. During stopping of the 16-bit free-run timer, the counter value can be set by writing the counter value to the TCDT.

#### Timer control status register (TCCSH, TCCSL)

The timer control status register (upper and lower) selects the count clock and the condition for clearing the counter, clears the counter, enables the count operation and interrupt request, checks the overflow generation flag.

# 13.2.2 Block Diagram of Input Capture

The input capture consist of the following blocks:

#### ■ Block Diagram of Input Capture



#### Input capture data registers 0 to 3 (IPCP0 to IPCP3)

- Input capture data register retains the counter value of the 16-bit free-run timer fetched by the capture operation.
- Input capture data register 0 to 3 keep the counter value of the 16-bit free-run timer 0

#### Input capture control status registers 01 to 23 (ICS01 to ICS23)

- Input capture control status register selects the trigger edge, enables the capture operation and capture interrupt request, and checks the valid edge detection flag for each input capture.
- Input capture control status register has 2 registers, and the input capture operation of the corresponding channel is controlled as shown in Table 13.2-2.

#### ● Input capture edge registers 01 to 23 (ICS01 to ICS23)

- Input capture control status register indicated the edge polarity detected by each input capture. Also, it selects the input signal (external pin INx/LIN-UART). When input is set to the LIN-UART, the baud rate measurement at the LIN slave operation can be performed (See "20.7.3 Operation with LIN Function (Operation Mode 3)").
- Input capture edge register has 2 registers, and the input capture operation of the corresponding channel is controlled as shown in Table 13.2-2.

Table 13.2-2 Relationship between the Register and Pin of Input Capture

|               | Input capture control status register | Input capture edge register | Input capture data register | Input<br>pin | Input form<br>LIN-UART |
|---------------|---------------------------------------|-----------------------------|-----------------------------|--------------|------------------------|
| Input capture | ICS01                                 | ICE01                       | IPCP0                       | IN0          | UART0                  |
| unit 0        |                                       |                             | IPCP1                       | IN1          | UART1                  |
|               | ICS23                                 | ICE23                       | IPCP2                       | IN2          | -                      |
|               |                                       |                             | IPCP3                       | IN3          | -                      |

#### Edge detection circuit

The edge detection circuit detects the edge of the signal input to the external input pin. The detected edge can be selected from among the rising edge, falling edge, both edges, and no detection (capture stop).

# 13.3 Configuration of 16-bit I/O Timer

This section explains the pins, registers, and interrupt factors of the 16-bit I/O timer.

#### ■ Pins of 16-bit I/O Timer

The pins of the 16-bit I/O timer serve as general-purpose I/O ports. Table 13.3-1 shows the pin functions and the pin settings required to use the 16-bit I/O timer.

Table 13.3-1 Pins of 16-bit I/O Timer

| Channel                 | Pin Name      | Pin Function                                   | Setting to use the pin                              |
|-------------------------|---------------|------------------------------------------------|-----------------------------------------------------|
| 16-bit free-run timer 0 | P44/<br>FRCK0 | General-purpose I/O port, external clock input | Set as input port in port direction register (DDR). |
| Input capture 0         | P24/IN0       | General-purpose I/O                            | Set as input port in port direction register (DDR). |
| Input capture 1         | P25/IN1       | port, capture input                            | Set as input port in port direction register (DDR). |
| Input capture 2         | P26/IN2       |                                                | Set as input port in port direction register (DDR). |
| Input capture 3         | P27/IN3       |                                                | Set as input port in port direction register (DDR). |

#### ■ Generation of Interrupt Request from 16-bit I/O Timer

The 16-bit I/O timer can generate an interrupt request as a result of the following factors:

#### Timer counter overflow interrupt

If the overflow interrupt request is set to enable (TCCSL: IVFE=1), the interrupt is occurred by the following factor:

• 16-bit free-run timer overflow

#### Input capture interrupt

If the input capture interrupt request is set to enable (ICS: ICE=1), if the trigger edge is detected by the input capture pin, or if the trigger edge for the LIN slave baud rate measurement from the LIN-UART is inputted, the interrupt request is generated.

# 13.3.1 Timer Control Status Register (Upper) (TCCSH)

Timer control status register (upper) selects the count clock and the conditions for clearing the counter, enables the count operation and interrupt, and checks the interrupt request flag.

#### ■ Timer Control Status Register (Upper) (TCCSH)



Table 13.3-2 Function of Timer Control Status Register (Upper) (TCCSH)

|                     | Bit name                              | Function                                                                                                                                                                                                                                                                                           |
|---------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15               | ECKE: External clock input enable bit | This bit selects the count clock of the 16-bit free-run timer.  When set to "1": Use the clock inputted from the external pin FRCKO.  When set to "0": Use the internal clock (clock outputted from the prescaler).  Note:  Set the ECKE bit during stopping of the free-run timer (TCCSL:STOP=1). |
| bit14<br>to<br>bit8 | Undefined bits                        | Read: The value is undefined Write: No effect                                                                                                                                                                                                                                                      |

# 13.3.2 Timer Control Status Register (Lower) (TCCSL)

The timer control status register (Lower) selects the count clock and conditions for clearing the counter, clears the counter, enables the count operation or interrupt, and checks the interrupt request flag.

#### ■ Timer Control Status Register (Lower) (TCCSL)



Table 13.3-3 Functions of Timer Control Status Register (Lower) (TCCSL)

|                      | Bit name                                                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|----------------------|----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit7                 | IVF: Timer overflow generation flag bit                  | This bit indicates the timer overflow.  [Condition set to "1"]  Condition is set when the following is used.  • When 16-bit free-run timer overflows  [When set to "1"]  When the timer overflow interrupt request is set to enable (TCCSL:IVFE if the IVF bit is set to "1", the interrupt request is generated.  When set to "0": The bit is cleared.  When set to "1": No effect.  Read by read modify write instructions: "1" is always read. |  |
| bit6                 | IVFE:<br>Timer overflow interrupt<br>enable bit          | This bit enables or disables the interrupt request when the IVF bit is set to "1".  When set to "1": When the IVF bit is set to "1", the interrupt request is generated.  When set to "0": The generation of the interrupt request is disabled.                                                                                                                                                                                                   |  |
| bit5                 | STOP:<br>Timer operation stop bit                        | This bit enables or disables (stops) the operation of the 16-bit free-run timer.  When set to "0": Enable the timer operation and count up with count clock set by the CLK2 to CLK0.  When set to "1":Stops count operation                                                                                                                                                                                                                       |  |
| bit4                 | Reserved bit                                             | Always set this bit to "0".                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| bit3                 | CLR:<br>Timer clear bit                                  | This bit clears the counter (TCDT) of the 16-bit free-run timer.  When set to "1": Clears timer data register (TCDT) to "0000 <sub>H</sub> "  When set to "0": No effect.  Read: "0" is always read.  Note:  When clearing during stopping of the 16-bit free-run timer  (TCCSL:STOP=1), write "0000 <sub>H</sub> " to the TCDT directly.                                                                                                         |  |
| bit2<br>bit1<br>bit0 | CLK2, CLK1, CLK0:<br>Count clock cycle selection<br>bits | These bits set the count clock to cycle of the 16-bit free-run timer.  Note:  Set the count clock cycle during stopping of the input capture operation (ICSnm: EGn1, EGn0="00 <sub>B</sub> " or ICSnm:EGm1, EGm0="00 <sub>B</sub> ").                                                                                                                                                                                                             |  |

n=0, 2 m=n+1

# 13.3.3 Timer Data Register (TCDT)

The timer data register is a 16-bit up counter.

- The counter value of the 16-bit free-run timer is read.
- The counter value can be set during stopping of the 16-bit free-run timer.

#### ■ Timer Data Register (TCDT)

Figure 13.3-3 Timer Data Register (TCDT)



The TCDT register can read the counter value of the 16-bit free-run timer.

#### [Condition for clear the counter value]

The counter value is cleared to "0000<sub>H</sub>" by the following conditions.

- Overflow
- Setting of "1" to the timer clear bit of the timer control status register (TCCSL:CLR=1)
- Setting of "0000<sub>H</sub>" to the timer data register during stopping of 16-bit free-run timer
- Reset

#### [Setting of counter value]

Write the counter value to the timer data register (TCDT) and set the timer during stopping the timer operation (TCCSL:STOP=1).

#### Note:

Always use a word instruction (MOVW) to read/write the timer data register.

# 13.3.4 Input Capture Control Status Registers (ICS)

The function of the input capture control status register is shown below.

The correspondence between ICS01 to ICS23 and input pin is as follows.

- ICS01: IN0, IN1 input capture ch0, ch1
- ICS23: IN2, IN3 input capture ch2, ch3

#### ■ Input Capture Control Status Registers (ICS01, ICS23)



Table 13.3-4 Functions of Input Capture Control Status Register (ICS)

|              | Bit name                                 | Function                                                                                                                                                                                                                                                                                                     |
|--------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7         | ICPm:<br>Valid edge detection flag bit m | This bit is set to "1" when the valid edge is detected by the INm pin.  When the interrupt request of the input capture m is set to enable (ICSnm:ICEm=1), if the ICPm bit is set, the interrupt request is generated.  When set to "0": The bit is cleared.  When set to "1": No effect.                    |
| bit6         | ICPn:<br>Valid edge detection flag bit n | This bit is set to "1" when the valid edge is detected by the INn pin.  When the interrupt request of the input capture m is set to enable (ICSnm:ICEn=1), if the ICPn bit is set, the interrupt request is generated.  When set to "1": The bit is cleared.  When set to "1": No effect.                    |
| bit5         | ICEm:<br>Capture interrupt enable bit m  | This bit enables or disables the interrupt request of the input capture m.  When set to "1": When the valid edge detection flag bit m is set to "1"  (ICSnm: ICPm=1), the interrupt request is generated.                                                                                                    |
| bit4         | ICEn:<br>Capture interrupt enable bit n  | This bit enables or disables the interrupt request of the input capture n.  When set to "1": When the valid edge detection flag bit n is set to "1"  (ICSnm: ICPn=1), the interrupt request is generated.                                                                                                    |
| bit3<br>bit2 | EGm1, EGm0:<br>Edge select bits m        | <ul> <li>For the input capture register m, the trigger edge of the capture operation is set.</li> <li>Setting of the trigger edge is used to specify enable and stop of the operation.</li> <li>When set to "00<sub>B</sub>": The operation of input capture is disabled and no edge is detected.</li> </ul> |
| bit1<br>bit0 | EGn1, EGn0:<br>Edge select bits n        | <ul> <li>For the input capture register n, the trigger edge of the capture operation is set.</li> <li>Setting of the trigger edge is used to specify enable and stop of the operation.</li> <li>When set to "00<sub>B</sub>": The operation of input capture is disabled and no edge is detected.</li> </ul> |

n = 0, 2 m = n + 1

# 13.3.5 Input Capture Register (IPCP)

Input capture register stores the counter value fetched from 16-bit free-run timer by the capture operation.

The IPCP register is the 16-bit read-only register and has the input capture registers 0 to 3 (IPCP0 to IPCP3).

#### ■ Input Capture Register (IPCP)

Figure 13.3-5 Input Capture Register (IPCP)

|                        | input dupturo regiotor (ii di )                                                                                                                                                                                                                                                                             |             |
|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|
| Address                | bit15 bit14 bit13 bit12 bit11 bit10 bit9 bit8                                                                                                                                                                                                                                                               | Reset value |
| IPCP0 (upper): 007921н | CP15 CP14 CP13 CP12 CP11 CP10 CP09 CP08                                                                                                                                                                                                                                                                     | XXXXXXX     |
| IPCP0 (lower): 007920н | R   R   R   R   R   R   R   R   R   R                                                                                                                                                                                                                                                                       | XXXXXXXB    |
| IPCP1 (upper): 007923н | bit15 bit14 bit13 bit12 bit11 bit10 bit9 bit8  CP15 CP14 CP13 CP12 CP11 CP10 CP09 CP08                                                                                                                                                                                                                      | XXXXXXX     |
| IPCP1 (lower): 007922H | R R R R R R R R R R R R R R R R R R R                                                                                                                                                                                                                                                                       | XXXXXXXB    |
| IPCP2 (upper): 007925н | bit15         bit14         bit13         bit12         bit11         bit10         bit9         bit8           CP15         CP14         CP13         CP12         CP11         CP10         CP09         CP08           R         R         R         R         R         R         R         R           | XXXXXXX     |
| IPCP2 (lower): 007924н | bit7   bit6   bit5   bit4   bit3   bit2   bit1   bit0     CP07   CP06   CP05   CP04   CP03   CP02   CP01   CP00     R   R   R   R   R   R   R   R   R                                                                                                                                                       | XXXXXXXB    |
| IPCP3 (upper): 007927н | bit15         bit14         bit13         bit12         bit11         bit10         bit9         bit8           CP15         CP14         CP13         CP12         CP11         CP10         CP09         CP08           R         R         R         R         R         R         R         R         R | XXXXXXX     |
| IPCP3 (lower): 007926H | bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0   CP07 CP06 CP05 CP04 CP03 CP02 CP01 CP00   R R R R R R R R R R R R                                                                                                                                                                                                 | XXXXXXX     |
| X : Undefined          |                                                                                                                                                                                                                                                                                                             |             |

When the trigger edge of the capture operation (ICSnm: set by EGn1, EGn0 or EGm1, EGm0) is detected by the IN0 to IN3 pins, the counter value of the 16-bit free-run timer is stored in the input capture registers 0 to 3 corresponding to each pin.

However, the input capture registers 0 and 1 can be selected a signal from the LIN-UART as the input signal (ICE: selected by IEI bit). See "13.3.6 Input Capture Edge Register (ICE)" for details.

The input capture register can be read, but can not be written.

$$n = 0,2$$
  $m = n+1$ 

#### Note:

Always use a word instruction (MOVW) to read the input capture register.

# 13.3.6 Input Capture Edge Register (ICE)

The input capture edge register has a function to indicate the selected edge direction and to select whether the input signal is inputted from either external pin or LIN-UART. By cooperating with the LIN-UART, the baud rate measurement at the LIN slave operation can be performed.

The correspondence between ICE01 to ICE23 / channel name and input pin (UART) name is shown as follows.

ICE01: input capture ch0, ch1 IN0(/UART0) IN1(/UART1)

ICE23: input capture ch2, ch3 IN2 IN3

#### ■ Input Capture Edge Register (ICE)



Table 13.3-5 Functions of Input Capture Edge Register 01 (ICE01)

|                      | Bit name                                 | Function                                                                                                                                                                                                                                                                                       |
|----------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit13 | Undefined bits                           | Read : The value is undefined.<br>Write: No effect.                                                                                                                                                                                                                                            |
| bit12                | ICUS1:<br>Input signal selection bit 1   | This bit selects the input signal used as the trigger of the input capture 1.  When set to "0": Select the external pin IN1.  When set to "1": Select the IN-UART1.                                                                                                                            |
| bit11                | Undefined bit                            | Read : The value is undefined.<br>Write: No effect.                                                                                                                                                                                                                                            |
| bit10                | ICUS0:<br>Input signal selection bit 0   | This bit selects the input signal used as the trigger of the input capture 0.  When set to "0": Select the external pin IN0.  When set to "1": Select the IN-UART0.                                                                                                                            |
| bit9                 | IEI1:<br>Detection edge indication bit 1 | This bit indicated the edge detected by the input capture 1 (rising/falling). This bit is read only. "0": Indicate that falling edge is detected. "1": Indicate that rising edge is detected. Note: This bit value is disabled when the capture operation is stopped (ICS01: EG11, EG10="00"). |
| bit8                 | IEI0:<br>Detection edge indication bit 0 | This bit indicated the edge detected by the input capture 0 (rising/falling). This bit is read only. "0": Indicate that falling edge is detected. "1": Indicate that rising edge is detected. Note: This bit value is disabled when the capture operation is stopped (ICS01: EG01, EG00="00"). |

Table 13.3-6 Functions of Input Capture Edge Register 23 (ICE23)

|                      | Bit name                                  | Function                                                                                                                                                                                                                                                                                                     |
|----------------------|-------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit10 | Undefined bits                            | Read : The value is undefined. Write: No effect.                                                                                                                                                                                                                                                             |
| bit9                 | IEI3:<br>Detection edge indication bit 3  | This bit indicates the edges detected by the input capture 3 (rising/falling). This bit is read only. "0": Indicate that falling edge is detected. "1": Indicate that rising edge is detected. Note: This bit value is disabled when the capture operation is stopped (ICSnm: EGm1, EGm0="00"). (n=2, m=n+1) |
| bit8                 | IEI2 :<br>Detection edge indication bit 2 | This bit indicates the edges detected by the input capture 2 (rising/falling). This bit is read only. "0": Indicate that falling edge is detected. "1": Indicate that rising edge is detected. Note: This bit value is disabled when the capture operation is stopped (ICS23: EG21, EG20="00").              |

#### Note:

In the input capture 0 and 1, if the input signal is selected to the LIN-UART (ICE01:ICUS), the input capture is used to calculate the baud rate when the LIN-UART operates the LIN slave. In this case, it must be set to the input capture interrupt enable (ICS01:ICE0=1 or ICE1=1) and to the detection of both edges (ICS01:EG01, EG00=11 $_B$  or EG11, EG10=11 $_B$ ). See "20.7.3 Operation with LIN Function (Operation Mode 3)" for details of the baud rate calculation.

## 13.4 Interrupts of 16-bit I/O Timer

The interrupt factors of the 16-bit I/O timer has overflow of the counter value in the 16-bit free-run timer, trigger edge input to the input capture input pin, and trigger edge input for the LIN slave baud rate measurement from the LIN-UART.

The El<sup>2</sup>OS can be started by the interrupt of the input capture.

#### ■ Interrupts of 16-bit I/O Timer

Table 13.4-1 shows interrupt control bits and interrupt factors of 16-bit I/O timer.

Table 13.4-1 Interrupts of 16-bit I/O Timer

|                                     | Timer counter overflow interrupt          | Input capture interrupt                                                                                                          |
|-------------------------------------|-------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|
| Interrupt request flag              | TCCSL: IVF                                | ICSnm: ICPn, ICPm                                                                                                                |
| Interrupt request output enable bit | TCCSL: IVFE                               | ICSnm: ICEn, ICEm                                                                                                                |
| Interrupt factor                    | Counter overflow of 16-bit free-run timer | Valid edge input to the input capture input pin and trigger edge input for the LIN slave baud rate measurement from the LIN-UART |

n = 0, 2 m = n+1

#### Timer counter overflow interrupt

#### When the timer overflow interrupt request is set:

The timer overflow generation flag of the timer control status register is set in the following cases (TCCSL:IVF=1).

• When overflow ("FFFF<sub>H</sub>"  $\rightarrow$  "0000<sub>H</sub>") occurs at counting up of the 16-bit free-run timer.

#### When the timer overflow interrupt request occurs:

When the timer overflow interrupt request is set to enable (TCCSL:IVFE=1) if the timer overflow generation flag is set to "1" (TCCSL:IVF=1), the interrupt request is generated.

#### Input capture Interrupt

When the valid edge set by the input capture pin (ICS:EG) is detected, or when the trigger edge for the LIN slave baud rate measurement from the LIN-UART is inputted (valid edge must be set to both edges), the interrupt is shown below.

- The counter value of the detected 16-bit free-run timer is stored to the input capture register.
- The valid edge detection flag of the input capture control status register is set to "1". (ICS: ICP=1)
- When the output of the input capture interrupt request is set to enable (ICS: ICE=1), the interrupt request is generated.

# ■ 16-bit I/O Timer Interrupt and El<sup>2</sup>OS

#### **Reference:**

For details of the interrupt number, interrupt control register, and interrupt vector address, see "CHAPTER 3 INTERRUPTS".

# ■ Correspondence to El<sup>2</sup>OS Function

The input capture corresponds to the EI<sup>2</sup>OS function.

However, to use the EI<sup>2</sup>OS function, it is necessary to disable other interrupt that shares the interrupt control register (ICR).

## 13.5 Explanation of Operation of 16-bit Free-run Timer

After a reset, the 16-bit free-run timer starts incrementing from " $0000_H$ ". The counter value of the 16-bit free-run timer is the base time of the input capture.

#### **■** Explanation of Operation of 16-bit Free-run Timer

Operation of the 16-bit free-run timer requires the setting shown in Figure 13.5-1.

Figure 13.5-1 Setting of 16-bit Free-run Timer bit15 14 12 11 10 9 bit8 bit7 6 5 bit0 TCCSH/TCCSL IVF **IVFE** STOP CLR CLK2 CLK1 CLK0  $\overline{\mathsf{x}}$ TCDT Counter value of 16-bit free-run timer O: Used bit X: Undefined bit 0 : Setting to "0"

#### [Setting of counter value in 16-bit free-run timer]

- Because the timer operation is enabled (TCCSL:STOP=0) after a reset, the 16-bit free-run timer starts incrementing from the counter value "0000<sub>H</sub>".
- When setting the counter value of the 16-bit free-run timer, disable the operation of the 16-bit free-run timer (TCCSL:STOP=1), set the value that starts counting to the timer data register, enable the timer operation (TCCSL:STOP=0).

#### [Generation of overflow and interrupt request]

- When overflow ("FFFF<sub>H</sub>"  $\rightarrow$  "0000<sub>H</sub>") occurs in the 16-bit free-run timer, the timer overflow generation flag is set to "1" (TCCSL:IVF) and starts incrementing from "0000<sub>H</sub>".
- When the timer overflow interrupt request is enabled (TCCSL:IVFE=1), the interrupt request is occurred.

#### [Clear factor of counter value and clear timing]

Table 13.5-1 shows the clear factor and clear timing of the 16-bit free-run timer.

Table 13.5-1 Clear Factor of Counter Value and Clear Timing

| Clear factor                                                              | Clear timing                          |
|---------------------------------------------------------------------------|---------------------------------------|
| When "1" to timer clear bit of timer control status register (TCCSL: CLR) | Synchronize with generation of factor |
| Write "0000 <sub>H</sub> " to timer data register during stopping         | Synchronize with generation of factor |
| Reset                                                                     | Synchronize with generation of factor |
| Timer overflow                                                            | Synchronize with count timing         |

Figure 13.5-2 shows counter clearing at an overflow.

Figure 13.5-2 Counter Clearing at an Overflow



# 13.6 Explanation of Operation of Input Capture

The input capture stores the counter value of the 16-bit free-run timer to the input capture register at the timing that is detected the input signal of the valid edge from the external input pin or that the trigger edge for the LIN slave baud rate measurement is inputted, the interrupt request is generated.

#### ■ Setting of Input Capture

Operation of the input capture requires the setting shown in Figure 13.6-1

bit15 bit8 bit7 bit0 ICPm ICPn ICEm | ICEn | EGm1 | EGm0 | EGn1 ICE/ICS IEIm IEIn EGn0 Hold counter value of input capture **IPCP** DDR port direction register Setting the corresponding bit using pin as capture input pin to "0". O: Using bit (Set the bit corresponding to used channel) ▲: Using bit (Exist only ICE01's bit, Set the bit at measurement LIN slave baud rate n = 0, 2 m = n + 1

Figure 13.6-1 Setting of Input Capture

#### [Input capture operation]

The following operation is executed when the set valid edge (ICS:EG) is detected in the input capture pin, or when the trigger edge for the LIN slave baud rate measurement from the LIN-UART is inputted.

- The counter value of the 16-bit free-run timer to time detected is stored in the input capture register.
- The detected edge direction is stored to the detection edge indication bit. (rising:IEI=1, falling:IEI=0)
- The valid edge detection flag of the input capture control status register is set to "1". (ICS:ICP=1)
- When the input capture interrupt request is enabled (ICS:ICE=1), the interrupt request is generated.
- To measure the baud rate at the LIN slave operation, it is necessary to set the input signal to the LIN-UART (ICE:ICUS), enable the input capture interrupt request (ICS:ICE=1), and set the valid edge to both edges (ICE:EG1, EG0=11<sub>B</sub>). See "20.7.3 Operation with LIN Function (Operation Mode 3)" for the calculation of the baud rate.

Figure 13.6-2 shows the timing of fetching a data for the input capture. Figure 13.6-3 shows the operation when valid edge is set to the rising edge/falling edge. Figure 13.6-4 shows the operation when valid edge is set to both edges.



φ Counter value Input capture input Capture signal Capture register Data fetch φ: Machine clock





# 13.7 Precautions when Using 16-bit I/O Timer

This section explains the precautions when using the 16-bit I/O timer.

#### ■ Precautions when Using 16-bit I/O Timer

- Precautions when setting 16-bit free-run timer
  - Do not change the count clock select bits (TCCSL: CLK2, CLK1, CLK0) during the operation in the 16-bit free-run timer (TCCSL: STOP = 0).
  - The counter value of the 16-bit free-run timer is cleared to " $0000_{
    m H}$ " by reset.
  - Stop the 16-bit free-run timer (TCCSL:STOP=1), then write the counter value to the timer data register (TCDT) directly.
  - Always use a word instruction to write the timer data register (TCDT).
- Operation delay by synchronization operation

The input capture generates delay of operation time because it synchronizes with the operation clock. After the input capture detects the trigger signal from the pin, it synchronizes with the machine clock and performs the capture operation.

# 13.8 Program Example of 16-bit I/O Timer

This section gives a program example of the 16-bit I/O timer.

#### ■ Program Example of 16-bit I/O Timer

#### Processing specification

- The cycle of a signal input to the INO pin is measured.
- The 16-bit free-run timer 0 and input capture 0 are used.
- The rising edge is selected as the trigger to be detected.
- The machine clock ( $\phi$ ) is 24 MHz and the count clock of the free-run timer is  $4/\phi$  (0.17  $\mu$ s).
- The timer overflow interrupt and input capture interrupt of input capture 0 are used.
- The overflow interrupt of the 16-bit free-run timer is counted beforehand and used for the cycle calculation.
- The cycle can be determined from the following equation:

```
Cycle = (overflow count \times "10000<sub>H</sub>" + nth IPCP0 value - (n-1)th IPCP0 value) \times count clock cycle = (overflow count \times 10000<sub>H</sub> + nth IPCP0 value - (n-1)th IPCP0 value) \times 0.17 \mus
```

# Coding example

```
ICR09 EQU 0000B9H
                             ; Interrupt control register
ICR11 EOU 0000BBH
                             ; Interrupt control register
      EQU 000012H
                             ;Port 2 direction register
DDR2
TCCSL EQU 007942H
                             ;Timer control status register
TCDT EQU 007940H
                             ;Timer data register
ICS01 EQU 000050H
                             ; Input capture control status register
IPCPO EQU 007920H
                             ;Input capture register 0
IVF0 EQU TCCSL:7
                             ;Timer overflow generation flag bit
ICPO EQU ICS01:6
                             ; Valid edge detection flag bit
DATA DSEG ABS=00H
      ORG
          0100H
OV CNT RW
           1 H
DATA ENDS
                             ;Overflow count counter
;------Main program------
CODE
           CSEG
START:
                             ;Stack pointer (SP),
                             ;already initialized
      AND
          CCR, #0BFH
                             ;Interrupt disable
      MOV I:ICR09,#00H
                             ;Interrupt level 0(strongest)
      MOV
           I:ICR11,#00H
                             ;Interrupt level 0(strongest)
      MOV I:DDR2, #00000000B ;Port 2 direction setting
      VOM
          I:TCCSL, #01001010B ; Count enable, Counter clear,
                             ;Overflow, Interrupt enable,
                             ;Count clock selection, Counter clear
```

```
MOV
           I:ICS01, #00010001B ; INO pin selection, External trigger,
                             ;IPCPO rising edge
                             ;Without IPCP1 edge detection
                             ;Clear each valid edge detection flag
                             ; Input capture interrupt request enable
      MOV
           ILM,#07H
                            ;Set ILM in PS to level 7
           CCR, #40H
                            ;Interrupt enable
      OR
LOOP:
      User processing
      :
          LOOP
      BRA
;-----Interrupt program------
WARI0:
      CLRB I:ICP0
                            ;Clear valid edge detection flag
                             ;Save OV-CNT and input capture value
      User processing
      :
      MOV
           A,0
                             ;Clear overflow count counter
      VOM
           OV_CNT,A
                            ; for next cycle measurement
      RETI
                            ;Recover from interrupt
WARI1:
      CLRB I:IVF0
                            ;Clear timer overflow generation flag
      INC OV_CNT
                            ; Increment overflow counter
      User processing
      RETI
                             ;Recover from interrupt
CODE
     ENDS
;-----Vector setting-----
      CSEG ABS=0FFH
VECT
      ORG 00FF78H
                            ;Setting vector to interrupt number #33(21H)
                            ; (Input capture)
      DSL
           WARI0
      ORG
           00FF84H
                            ;Setting vector to interrupt number \#30(1E_{H})
                             ; (Overflow)
      DSL
           WARI1
      ORG
           00FFDCH
                            ;Reset vector setting
      DSL
           START
      DB
           00H
                            ;Setting to single-chip mode
VECT
      ENDS
      END
          START
```

# CHAPTER 14

# 16-BIT RELOAD TIMER

This chapter describes the functions and operation of the 16-bit reload timer.

- 14.1 Overview of the 16-bit Reload Timer
- 14.2 Block Diagram of 16-bit Reload Timer
- 14.3 Configuration of 16-bit Reload Timer
- 14.4 Interrupts of 16-bit Reload Timer
- 14.5 Explanation of Operation of 16-bit Reload Timer
- 14.6 Precautions when Using 16-bit Reload Timer
- 14.7 Sample Program of 16-bit Reload Timer

#### 14.1 Overview of the 16-bit Reload Timer

The 16-bit reload timer has the following functions:

- The count clock can be selected from three internal clocks and external event clocks.
- A software trigger or external trigger can be selected as the start trigger.
- If the 16-bit timer register (TMR) underflows, an interrupt can be generated to the CPU. The 16-bit reload timer can be used as an interval timer by using an interrupt.
- If the TMR underflows, either the one-shot mode for stopping the TMR count operation, or the reload mode for reloading the value of the 16-bit reload register (TMRLR) to the TMR to continue the TMR count operation can be selected.
- The 16-bit reload timer corresponds to the El<sup>2</sup>OS (correspond to 2 channels).
- The MB90360 series has two channels of 16-bit reload timers.

#### ■ Operation Modes of 16-bit Reload Timer

Table 14.1-1 indicates the operation modes of the 16-bit reload timer.

Table 14.1-1 Operation Modes of 16-bit Reload Timer

| Count clock         | Start trigger                        | Operation performed upon underflow |
|---------------------|--------------------------------------|------------------------------------|
| Internal clock mode | Software trigger<br>External trigger | One-shot mode<br>Reload mode       |
| Event count mode    | Software trigger                     | One-shot mode<br>Reload mode       |

#### **■ Internal Clock Mode**

- When the count clock select bits in the timer control status register (TMCSR:CSL1, CSL0) are set to "00<sub>B</sub>", "01<sub>B</sub>" or "10<sub>B</sub>", the 16-bit reload timer is set in the internal clock mode.
- In the internal clock mode, the 16-bit reload timer decrements in synchronization with the internal clock.
- The count clock select bits in the timer control status register (TMCSR:CSL1, CSL0) can be used to select three count clock cycles.
- The start trigger sets the edge detection for a software trigger or an external trigger.

#### **■** Event Count Mode

- When the count clock select bits in the timer control status register (TMCSR:CSL1, CSL0) are set to "11<sub>B</sub>", the 16-bit reload timer is set to the event count mode.
- In the event count mode, the 16-bit reload timer decrements in synchronization with the edge detection of the external event clock input to the TIN pin.
- A software trigger is selected as the start trigger.
- The 16-bit reload timer can be used as an interval timer by using a fixed cycle of the external clock.

#### ■ Operation at Underflow

When the start trigger is inputted, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register, starting decrementing in synchronization with the count clock. When the 16-bit timer register (TMR) is decremented from " $0000_H$ " to "FFFF<sub>H</sub>", an underflow occurs.

- When an underflow occurs with an underflow interrupt enabled (TMCSR:INTE = 1), an underflow interrupt is generated.
- The 16-bit reload timer operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR:RELD).

#### [One-shot mode (TMCSR: RELD=0)]

When an underflow occurs, the TMR count operation is stopped. When the next start trigger is inputted, the value set in the TMRLR is reloaded in the TMR, starting the TMR count operation.

- In the one-shot mode, during the TMR count operation, a High-level or Low-level rectangular wave is outputted from the TOT pin.
- The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of the rectangular wave.

#### [Reload mode (TMCSR: RELD=1)]

When an underflow occurs, the value set in the TMRLR is reloaded to the TMR, continuing the TMR count operation.

- In the reload mode, a toggle wave inverting the output level of the TOT pin is outputted each time an underflow occurs during the TMR count operation.
- The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of a toggle wave at starting the reload timer.
- The 16-bit reload timer can be used as an interval timer by using an underflow interrupt.

Table 14.1-2 Interval Time for the 16-bit Reload Timer

| Count clock         | Count clock period         | Interval time       |
|---------------------|----------------------------|---------------------|
|                     | 2 <sup>1</sup> T(0.083 μs) | 0.083 μs to 5.46 ms |
| Internal clock mode | $2^{3}$ T(0.33 µs)         | 0.33 μs to 21.8 ms  |
|                     | $2^5 T(1.3 \mu s)$         | 1.3 μs to 87.4 ms   |
| Event count mode    | 2 <sup>3</sup> T or more   | 0.33 μs or more     |

T: Machine cycle

The values in interval time and the parenthesized values are provided when the machine clock operates at 24 MHz.

## 14.2 Block Diagram of 16-bit Reload Timer

The 16-bit reload timers 2 and 3 composed of the following seven blocks:

- Count clock generator
- Reload controller
- Output controller
- Operation controller
- 16-bit timer register (TMR)
- 16-bit reload register (TMRLR)
- Timer control status register (TMCSR)

#### ■ Block Diagram of 16-bit Reload Timer

Figure 14.2-1 Block Diagram of 16-bit Reload Timer



#### Details of pins in block diagram

There are two channels for 16-bit reload timer.

The actual pin names, outputs to resources, and interrupt request numbers for each channel are as follows:

Table 14.2-1 Pin Names, Outputs to Resources, and Interrupt Request Numbers of 16-bit Reload Timer

|                          | Reload timer 2        | Reload timer 3        |
|--------------------------|-----------------------|-----------------------|
| TIN pin                  | P82                   | P53                   |
| TOT pin                  | P83                   | P54                   |
| Output to resources      | -                     | -                     |
| Interrupt request number | #19(13 <sub>H</sub> ) | #20(14 <sub>H</sub> ) |

#### Count clock generator

The count clock generator generates a count clock supplied to the 16-bit timer register (TMR) on the basis of the machine clock or external event clock.

#### Reload controller

When the 16-bit reload timer starts operation or the TMR underflows, the reload controller reloads the value set in the 16-bit reload register (TMRLR) to the TMR.

#### Output controller

The output controller inverts and enables or disables the output of the TOT pin at underflow.

#### Operation controller

The operation controller starts or stops the 16-bit reload timer.

#### • 16-bit timer register (TMR)

The 16-bit timer register (TMR) is a 16-bit down counter. At read, the value being counted is read.

#### 16-bit reload register (TMRLR)

The 16-bit reload register (TMRLR) sets the interval time of the 16-bit reload timer. When the 16-bit reload timer starts operation or the 16-bit timer register (TMR) underflows, the value set in the TMRLR is reloaded to the TMR.

#### Timer control status register (TMCSR)

The timer control status register (TMCSR) selects the operation mode, sets the operation conditions, selects the start trigger, performs a start using the software trigger, selects the reload operation mode, enables or disables an interrupt request, sets the output level of the TOT pin, and sets the TOT output pin of the 16-bit reload timer.

## 14.3 Configuration of 16-bit Reload Timer

This section explains the pins, registers, and interrupt factors of the 16-bit reload timer.

#### ■ Pins of 16-bit Reload Timer

The pins of the 16-bit reload timer serve as general-purpose I/O ports. Table 14.3-1 shows the pin functions and the pin settings required to use the 16-bit reload timer.

Table 14.3-1 Pins of 16-bit Reload Timer

| Pin<br>name                         | Pin function                                                                                        | Pin Setting Required for Use in 16-bit Reload Timer                                                                                                                                                                                                                        |  |  |  |  |
|-------------------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| P82 /<br>SIN0 /<br>INT14R /<br>TIN2 | General-purpose I/O port/<br>UART input 0/<br>External interrupt 14/<br>16-bit reload timer input 2 | <ul> <li>Port direction register: Setting for the input port (DDR8:D82=0)</li> <li>Serial control register: Setting for the reception disable         (SCR0:RXE=0)</li> <li>Disable the external interrupt (external interrupt enable register ENIR1: EN14 = 0)</li> </ul> |  |  |  |  |
| P83 /<br>SOT0 /<br>TOT2             | General-purpose I/O port/<br>UART output 0/<br>16-bit reload timer output 2                         | <ul> <li>Serial control register : Setting for the transmission disable (SCR0:TXE=0)</li> <li>Timer control status register: Enable the timer output (TMCSR2: OUTE=1)</li> </ul>                                                                                           |  |  |  |  |
| P53 /<br>AN11 /<br>TIN3             | General-purpose I/O port/<br>A/D converter analog input 11/<br>16-bit reload timer input 3          | <ul> <li>Port direction register : Setting for the input port (DDR5:D53=0)</li> <li>Analog input enable register: Setting for the prohibition (ADER5:ADE11=0)</li> </ul>                                                                                                   |  |  |  |  |
| P54 /<br>AN12 /<br>TOT3             | General-purpose I/O port/<br>A/D converter analog input 12/<br>16-bit reload timer output 3         | <ul> <li>Analog input enable register: Setting for the prohibition</li></ul>                                                                                                                                                                                               |  |  |  |  |

### ■ 16-bit Reload Timer Registers and Reset Value

• 16-bit reload timer 2 register

Figure 14.3-1 List of 16-bit Reload Timer 2 Register and Reset Value

|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|----------------------------------------------|-----|----|----|----|----|----|----|---|---|
| Timer Control Status Register Upper (TMCSR2) |     | Х  | Х  | Х  | Х  | 0  | 0  | 0 | 0 |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| Timer Control Status Register Lower (TMCSR2) |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 16-bit Timer Register Upper (TMR2)           |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| 16-bit Timer Register Lower (TMR2)           |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 16-bit Reload Register Upper (TMRLR2)        |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| 16-bit Reload Register Lower (TMRLR2)        |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
| X : Undefined                                |     |    |    |    |    |    |    |   |   |

• 16-bit reload timer 3 register

Figure 14.3-2 List of 16-bit Reload Timer 3 Register and Reset Value

|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
|----------------------------------------------|-----|----|----|----|----|----|----|---|---|
| Timer Control Status Register Upper (TMCSR3) |     | Х  | Х  | Х  | Х  | 0  | 0  | 0 | 0 |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| Timer Control Status Register Lower (TMCSR3) |     | 0  | 0  | 0  | 0  | 0  | 0  | 0 | 0 |
|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 16-bit Timer Register Upper (TMR3)           |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| 16-bit Timer Register Lower (TMR3)           |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х |
|                                              | bit | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 |
| 16-bit Reload Register Upper (TMRLR3)        |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | X |
|                                              | bit | 7  | 6  | 5  | 4  | 3  | 2  | 1 | 0 |
| 16-bit Reload Register Lower (TMRLR3)        |     | Х  | Х  | Х  | Х  | Х  | Х  | Х | Х |
| X : Undefined                                |     |    |    |    |    |    |    |   |   |

#### ■ Generation of Interrupt Request from 16-bit Reload Timer

When the 16-bit reload timer is started and the count value of the 16-bit timer register is decremented from " $0000_H$ " to "FFFF $_H$ ", an underflow occurs. When an underflow occurs, the UF bit in the timer control status register is set to 1 (TMCSR:UF). If an underflow interrupt is enabled (TMCSR:INTE = 1), an interrupt request is generated.

## 14.3.1 Timer Control Status Registers (High) (TMCSR:H)

The timer control status registers (High) (TMCSR:H) set the operation mode and count clock.

This section also explains the bit 7 in the timer control status registers (Low) (TMCSR:L).

#### ■ Timer Control Status Registers (High) (TMCSR:H)



Table 14.3-2 Functions of Timer Control Status Registers (High) (TMCSR: H)

| Bit name             |                                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------------------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit12 | Undefined bits                                     | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| bit11<br>bit10       | CSL1, CSL0:<br>Count clock select bits             | These bits select the count clock of the 16-bit reload timer.  When set to anything other than "11 <sub>B</sub> ": These bit is counted by internal clock (internal clock mode).  When set to "11 <sub>B</sub> ": The edge of the external event clock is counted (event count mode).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| bit9<br>to<br>bit7   | MOD2, MOD1, MOD0:<br>Operating mode select<br>bits | These bits set the operation conditions of the 16-bit reload timer.  [Internal clock mode] The MOD2 bit is used to select the function of the input pin.  When MOD2 bit set to 0:  The input pin functions as a trigger input.  The MOD1 and MOD0 bits are used to select the edge to be detected.  When the edge is detected, the value set in the 16-bit reload register (TMRLR) is reloaded in the 16-bit timer register (TMR), starting the count operation of the TMR.  When MOD2 set to 1:  The input pin functions as a gate input.  The MOD1 bit is not used. The MOD0 bit is used to select the signal level (High or Low) to be detected. The count operation of the 16-bit timer register (TMR) is performed only when the signal level is inputted.  [Event count mode] The MOD2 bit is not used. An external event clock is inputted from the input pin. The MOD1 and MOD0 bits are used to select the edge to be detected. |

## 14.3.2 Timer Control Status Registers (Low) (TMCSR: L)

The timer control status registers (Low) (TMCSR:L) enables or disable the timer operation, check the generation of a software trigger or an underflow, enables or disable an underflow interrupt, select the reload mode, and set the output of the TOT pin.

#### ■ Timer Control Status Registers (Low) (TMCSR: L)



Table 14.3-3 Timer Control Status Registers (Low) (TMCSR: L)

| Bit Name |                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------|---------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit6     | OUTE:<br>TOT pin Output enable bit          | This bit sets the function of the TOT pin of the 16-bit reload timer.  When set to 0: Functions as general-purpose I/O port  When set to 1: Functions as TOT pin of 16-bit reload timer                                                                                                                                                                                                                                                                                                 |
| bit5     | OUTL:<br>TOT Pin output level select<br>bit | This bit sets the output level of the output pin of the 16-bit reload timer. <one-shot (reld="0)" mode="">  When set to 0: Outputs High-level rectangular wave during TMR count operation  When set to 1: Outputs Low-level rectangular wave during TMR count operation  <reload (reld="1)" mode="">  When set to 0: Outputs Low-level toggle wave when 16-bit reload timer started  When set to 1: Outputs High-level toggle wave when 16-bit reload timer started</reload></one-shot> |
| bit4     | RELD:<br>Reload select bit                  | This bit sets the reload operation at underflow.  When set to 1: At underflow, reloads value set in TMRLR to TMR, continuing count operation (reload mode)  When set to 0: At underflow, stops count operation (one-shot mode)                                                                                                                                                                                                                                                          |
| bit3     | INTE:<br>Underflow interrupt enable<br>bit  | This bit enables or disables an underflow interrupt.  When an underflow occurs (TMCSR:UF = 1) with an underflow interrupt enabled (TMCSR:INTE = 1), an interrupt request is generated.                                                                                                                                                                                                                                                                                                  |
| bit2     | UF:<br>Underflow generating flag<br>bit     | This bit indicates that the TMR underflows.  When set to 0: Clears this bit  When set to 1: No effect  Read by read modify write instructions: 1 is always read.                                                                                                                                                                                                                                                                                                                        |
| bit1     | CNTE:<br>Timer operation enable bit         | This bit enables or disables the operation of the 16-bit reload timer.  When set to 1: 16-bit reload timer enters start trigger wait state. When the start trigger is inputted, the count operation of the TMR is restarted.  When set to 0: Stops count operation                                                                                                                                                                                                                      |
| bit0     | TRG:<br>Software trigger bit                | This bit starts the 16-bit reload timer by software. The software trigger function works only when the timer operation is enabled (CNTE = 1).  When set to 0: Disabled. The state remains unchanged. When set to 1: Reloads value set in 16-bit reload register (TMRLR) to 16-bit timer register (TMR), starting TMR count operation Read: 0 is always read.                                                                                                                            |

## 14.3.3 16-bit Timer Registers (TMR)

The 16-bit timer registers are 16-bit down counters. At read, the value being counted is read.

#### ■ 16-bit Timer Registers (TMR)

Figure 14.3-5 16-bit Timer Registers (TMR)



When the timer operation is enabled (TMCSR:CNTE = 1) and the start trigger is inputted, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation.

When the timer operation is disabled (TMCSR:CNTE = 0), the TMR value is retained.

When the TMR value is counted down from " $0000_{\rm H}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

#### [Reload mode]

When the TMR underflows, the value set in the TMRLR is reloaded to the TMR, restarting the TMR count operation.

#### [One-shot mode]

When the TMR underflows, the TMR count operation is stopped, entering the start trigger input wait state. The TMR value is retained to "FFFF $_H$ ".

#### **Notes:**

- The TMR can be read during the TMR count operation. However, always use the word instruction (MOVW).
- The TMR and the TMRLR are assigned to the same address. At write, the set value can be written to the TMRLR without affecting the TMR. At read, the TMR value being counted can be read.

## 14.3.4 16-bit Reload Registers (TMRLR)

The 16-bit reload registers set the value to be reloaded to the 16-bit timer register (TMR). When the start trigger is inputted, the value set in the 16-bit reload registers is reloaded to the TMR, starting the TMR count operation.

#### ■ 16-bit Reload Registers (TMRLR)

Figure 14.3-6 16-bit Reload Registers (TMRLR)

15 14 13 12 11 10 9 8 Reset



Set the 16-bit reload registers after disabling the timer operation (TMCSR:CNTE = 0). After completing setting of the 16-bit reload registers, enable the timer operation (TMCSR:CNTE = 1).

When the start trigger is inputted, the value set in the TMRLR is reloaded to the TMR, starting the TMR count operation.

#### **Notes:**

- Perform a write to the TMRLR after disabling the operation of the 16-bit reload timer (TMCSR:CNTE = 0). Always use the word instruction (MOVW).
- The TMRLR and the TMR are assigned to the same address. At write, the set value can be written to the TMRLR without affecting the TMR. At read, the TMR value being counted is read.
- Instructions, such as the INC/DEC instruction, which provide the read modify write (RMW) operation
  cannot be used.

## 14.4 Interrupts of 16-bit Reload Timer

The 16-bit reload timer generates an interrupt request when the 16-bit timer register (TMR) underflows.

#### ■ Interrupts of 16-bit Reload Timer

When the value of the TMR is decremented from " $0000_H$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs. When an underflow occurs, the underflow generating flag bit in the timer control status register (TMCSR:UF) is set to 1. When an underflow interrupt is enabled (TMCSR:INTE = 1), an interrupt request is generated.

Table 14.4-1 Interrupt Control Bits and Interrupt Factors of 16-bit Reload Timer

|                              | 16-bit Reload Timer 2 | 16-bit Reload Timer 3 |
|------------------------------|-----------------------|-----------------------|
| Interrupt request flag bit   | TMCSR2: UF            | TMCSR3: UF            |
| Interrupt request enable bit | TMCSR2: INTE          | TMCSR3: INTE          |
| Interrupt factor             | Underflow in TMR2     | Underflow in TMR3     |

## ■ Correspondence between 16-bit Reload Timer Interrupt and El<sup>2</sup>OS

Reference:

For details of the interrupt number, interrupt control register, and interrupt vector address, see "CHAPTER 3 INTERRUPTS".

#### ■ El<sup>2</sup>OS Function of 16-bit Reload Timer

The 16-bit reload timers 2 and 3 correspond to the EI<sup>2</sup>OS function. An underflow in the TMR starts the EI<sup>2</sup>OS.

However, the EI<sup>2</sup>OS is available only when other resources sharing the interrupt control register (ICR) do not use interrupts. The 16-bit reload timers 2 and 3 share the ICR04. When using the EI<sup>2</sup>OS in the 16-bit reload timers 2 and 3, it is necessary to disable the interrupt of the 16-bit reload timer sharing the interrupt control register.

## 14.5 Explanation of Operation of 16-bit Reload Timer

This section explains the setting of the 16-bit reload timer and the operation state of the counter.

#### ■ Setting of 16-bit Reload Timer

Setting of internal clock mode

Counting the internal clock requires the setting shown in Figure 14.5-1.

Figure 14.5-1 Setting of Internal Clock Mode



Setting of event count mode

Inputting an external event to operate the 16-bit reload timer requires the setting shown in Figure 14.5-2.

Figure 14.5-2 Setting of Event Count Mode



#### ■ Operating State of 16-bit Timer Register

The operating state of the 16-bit timer register is determined by the timer operation enable bit in the timer control status register (TMCSR:CNTE) and the WAIT signal. The operating states include the stop state, start trigger input wait state (WAIT state), and RUN state.

Figure 14.5-3 shows the state transition diagram for the 16-bit timer registers.



## 14.5.1 Operation in Internal Clock Mode

In the internal clock mode, three operation modes can be selected by setting the operating mode select bits in the timer control status register (TMCSR:MOD2 to MOD0). When the operation mode and reload mode are set, a rectangular wave or a toggle wave is outputted from the TOT pin.

#### ■ Setting of Internal Clock Mode

- By setting the count clock select bits (CSL1, CSL0) in the timer control status register to "00<sub>B</sub>", "01<sub>B</sub>" and "10<sub>B</sub>", the 16-bit reload timer (TMRLR) is set to the internal clock mode.
- In the internal clock mode, the 16-bit timer register (TMR) decrements in synchronization with the internal clock.
- In the internal clock mode, three count clock cycles can be selected by setting the count clock select bits in the timer control status register (TMCSR:CSL1, CSL0).

#### [Setting a reload value to TMR]

After the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR.

- 1. Disables the timer operation (TMCSR:CNTE = 0).
- 2. Sets a reload value to the TMR in the TMRLR.
- 3. Enables the timer operation (TMCSR:CNTE = 1).

#### Note:

It takes 1 T (T: machine cycle (time) to load the value set in the TMRLR to the TMR after the start trigger is inputted.

#### ■ Operation as 16-bit Timer Register Underflows

When the value of the 16-bit timer register (TMR) is decremented from " $0000_{\rm H}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

- When an underflow occurs, the underflow generating flag bit in the timer control status register (TMCSR:UF) is set to 1.
- When the underflow interrupt enable bit in the timer control status register (TMCSR:INTE) is set to 1, an underflow interrupt is generated.
- The reload operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR:RELD).

#### [One-shot mode (TMCSR:RELD = 0)]

When an underflow occurs, the count operation of the TMR is stopped, entering the start trigger input wait state. When the next start trigger is inputted, the TMR count operation is restarted.

In the one-shot mode, a rectangular wave is outputted from the TOT pin during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of a rectangular wave.

#### [Reload mode (TMCSR:RELD = 1)]

When an underflow occurs, the value set in the 16-bit reload timer register (TMRLR) is reloaded to the TMR, continuing the TMR count operation.

In the reload mode, a toggle wave inverting the output level of the TOT pin is outputted each time an underflow occurs during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of a toggle wave as the 16-bit reload timer is started.

#### ■ Operation in Internal Clock Mode

In the internal clock mode, the operation mode select bits in the timer control status register (TMCSR:MOD2 to MOD0) can be used to select the operation mode. Disable the timer operation by setting the timer operation enable bit in the timer control status register (TMCSR:CNTE to 0).

#### [Software trigger mode (MOD2 to MOD0="000<sub>R</sub>")]

If the software trigger mode is set, start the 16-bit reload timer by setting the software trigger bit in the timer control status register (TMCSR:TRG) to 1. When the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR, starting the TMR count operation.

#### Note:

When both the timer operation enable bit in the timer control status register (TMCSR:CNTE) and the software trigger bit in the timer control status register (TMCSR:TRG) are set to 1, the 16-bit reload timer and the count operation of the TMR are started simultaneously.



Figure 14.5-4 Count Operation in Software Trigger Mode (One-shot Mode)





#### [External trigger mode (MOD2 to MOD0="001<sub>B</sub>", "010<sub>B</sub>", "011<sub>B</sub>")]

When the external trigger mode is set, the 16-bit reload timer is started by inputting the external valid edge to the TIN pin. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation.

By setting the operating mode select bits in the timer control status register (TMCSR:MOD2 to MOD0), the detected edge can be selected from the rising edge, falling edge, and both edges.

#### Note:

The trigger pulse width of the edge to be inputted to the TIN pin should be 2 T (T: machine cycles) or more.



Figure 14.5-6 Count Operation in External Trigger Mode (One-shot Mode)





#### [External gate input mode (MOD2 to MOD0="1x0B", "1x1B")]

When the external gate input mode is set, start the 16-bit reload timer by setting the software trigger bit in the timer control status register (TMCSR:TRG) to 1. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR).

- After the 16-bit reload timer is started, the count operation of the TMR is performed while the set gate input level is inputted to the TIN pin.
- The gate input level (High or Low) can be selected by setting the operating mode select bits in the timer control status register (TMCSR:MOD2 to MOD0).



Figure 14.5-8 Count Operation in External Gate Input Mode (One-shot Mode)





## 14.5.2 Operation in Event Count Mode

In the event count mode, after the 16-bit reload timer is started, the edge of the signal input to the TIN pin is detected to perform the count operation of the 16-bit timer register (TMR). When the operation mode and the reload mode are set, a rectangular wave or a toggle wave is outputted from the TOT pin.

#### ■ Setting of Event Count Mode

- The 16-bit reload timer is placed in the event count mode by setting the count clock select bits in the timer control status register (TMCSR:CSL1, CSL0) to "11<sub>B</sub>".
- In the event count mode, the TMR decrements in synchronization with the edge detection of the external event clock input to the TIN pin.

#### [Setting initial value of counter]

After the 16-bit reload timer is started, the value set in the TMRLR is reloaded to the TMR.

- 1. Disables the operation of the 16-bit reload timer (TMCSR:CNTE = 0).
- 2. Sets a reload value to the TMR in the TMRLR.
- 3. Enables the operation of the 16-bit reload timer (TMCSR:CNTE = 1).

#### Note:

It takes 1 T (T: machine cycle) to load the value set in the TMRLR to the TMR after the start trigger is inputted.

#### ■ Operation as 16-bit Timer Register Underflows

When the value of the 16-bit timer register (TMR) is decremented from " $0000_{\rm H}$ " to "FFFF<sub>H</sub>" during the TMR count operation, an underflow occurs.

- When an underflow occurs, the underflow generating flag bit in the timer control status register (TMCSR:UF) is set to 1.
- When the underflow interrupt enable bit in the timer control status register (TMCSR:INTE) is set to 1, an underflow interrupt is generated.
- The reload operation when an underflow occurs is set by the reload select bit in the timer control status register (TMCSR:RELD).

#### [One-shot mode (TMCSR: RELD=0)]

When an underflow occurs, the TMR count operation is stopped, entering the start trigger input wait state. When the next start trigger is inputted, the TMR count operation is restarted.

In the one-shot mode, a rectangular wave is outputted from the TOT pin during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of the rectangular wave.

#### [Reload mode (TMCSR: RELD=1)]

When an underflow occurs, the value set in the TMRLR is reloaded to the TMR, continuing the TMR count operation.

In the reload mode, a toggle wave inverting the output level of the TOT pin is outputted each time an underflow occurs during the TMR count operation. The pin output level select bit in the timer control status register (TMCSR:OUTL) can be set to select the level (High or Low) of the toggle wave when the 16-bit reload timer is started.

#### **■** Operation in Event Count Mode

The operation of the 16-bit reload timer is enabled by setting the timer operation enable bit in the timer control status register (TMCSR:CNTE) to 1. When the software trigger bit in the timer control status register (TMCSR:TRG) is set to 1, the 16-bit reload timer is started. When the 16-bit reload timer is started, the value set in the 16-bit reload register (TMRLR) is reloaded to the 16-bit timer register (TMR), starting the TMR count operation. After the 16-bit reload timer is started, the edge of the external event clock input to the TIN pin is detected to perform the TMR count operation.

• By setting the operating mode select bits in the timer control status register (TMCSR:MOD2 to MOD0), the detected edge can be selected from the rising edge, falling edge, and both edges.

#### Note:

The level width of the external event clock to be inputted to the TIN pin should be 4 T (T: machine cycles) or more.



Figure 14.5-10 Count Operation in Event Count Mode (One-shot Mode)





## 14.6 Precautions when Using 16-bit Reload Timer

This section explains the precautions when using the 16-bit reload timer.

#### ■ Precautions when Using 16-bit Reload Timer

- Precautions when setting by program
  - Set the 16-bit reload register (TMRLR) after disabling the timer operation (TMCSR:CNTE = 0)
  - The 16-bit timer register (TMR) can be read during the TMR count operation. However, always use the word instruction.
  - Change the CSL1 and CSL0 bits in the TMCSR after disabling the timer operation (TMCSR:CNTE = 0)
- Precautions on interrupt
  - When the UF bit in the TMCSR is set to 1 and the underflow interrupt output is enabled (TMCSR:INTE = 1), it is impossible to return from interrupt processing. Always clear the UF bit. However, when the EI<sup>2</sup>OS is used, the UF bit is cleared automatically.
  - When using the EI<sup>2</sup>OS in the 16-bit reload timer, it is necessary to disable the interrupt of the 16-bit reload timer that shares the interrupt control register (ICR).

## 14.7 Sample Program of 16-bit Reload Timer

This section gives a program example of the 16-bit reload timer operated in the internal clock mode and the event count mode:

#### ■ Program Example in Internal Clock Mode

- Processing specification
  - The 24 ms interval timer interrupt is generated by the 16-bit reload timer 2.
  - The repeated interrupts are generated in the reload mode.
  - The timer is started using the software trigger instead of the external trigger input.
  - EI<sup>2</sup>OS is not used.
  - The machine clock is 24 MHz; the count clock is 1.33  $\mu s.\,$

#### Coding example

```
ICR04 EQU 0000B4H
                           ;Interrupt control register for 16-bit
                           ;reload timer
TMCSR2 EQU 000064H
                           ;Timer control status register
TMR2
      EQU 00794CH
                           ;16-bit timer register
TMRLR2 EQU 00794CH
                           ;16-bit reload register
                           ; Interrupt request flag bit
UF2
      EQU TMCSR2:2
CNTE2 EQU TMCSR2:1
                           ; Counter operation enable bit
TRG2 EQU TMCSR2:0
                           ;Software trigger bit
;------Main program------
CODE
      CSEG
       :
                           ;Stack pointer (SP), already initialized
      AND CCR, #0BFH
                           ;Interrupts disabled
      MOV I:ICR04,#00H
                           ;Interrupt level 0 (highest)
      CLRB I:CNTE2
                           ; Counter suspended
      MOVW I:TMRLR2, #4650H ; Set data for 24 ms timer
      MOVW I:TMCSR2, #0000100000011011B
                           ;Operation of interval timer,
                            clock = 1.33 \mu s
                           ;External trigger disabled, external
                            output disabled
                           ; Reload mode selected, interrupt enabled
                           ; Interrupt flag cleared, count started
      MOV ILM, #07H
                           ;ILM in PS set to level 7
                           ;Interrupts enabled
       OR
           CCR, #40H
LOOP:
       Processing by user
```

```
BRA LOOP
;-----Interrupt program------
WARI:
     CLR I:UF2
                       ; Interrupt request flag cleared
      :
      Processing by user
      :
      RETI
                       ;Return from interrupt
CODE
     ENDS
;------Vector setting------
VECT
     CSEG ABS=0FFH
     ORG 00FFB0H
                      ;Set vector to interrupt #19(13<sub>H</sub>)
     DSL WARI
      ORG 00FFDCH
                      ;Reset vector set
     DSL START
     DB
          00H
                       ;Set to single-chip mode
     ENDS
VECT
     END START
```

#### **■ Program Example in Event Counter Mode**

#### Processing specification

- An interrupt is generated when rising edges of the pulse input to the external event input pin are counted 10000 times by the 16-bit reload timer 2.
- Operation is performed in the one-shot mode.
- The rising edge is selected for the external trigger input.
- EI<sup>2</sup>OS is not used.

#### Coding example

```
ICR04 EOU 0000B4H
                         ;Interrupt control register for 16-bit
                         ;reload timer
TMCSR2 EQU 000064H
                         ;Timer control status register
                         ;16-bit timer register
TMR2
      EQU 00794CH
                         ;16-bit reload register
TMRLR2 EQU 00794CH
DDR8
      EQU 000018H
                         ;Port data register
UF2
      EQU TMCSR2:2
                         ;Interrupt request flag bit
CNTE2 EQU TMCSR2:1
                         ; Counter operation enable bit
TRG2
      EQU TMCSR2:0
                         ;Software trigger bit
;-----Main program------
CODE
      CSEG
                         ;Stack pointer (SP), already initialized
      :
                         ;Used at software starting mode(ACS1 :
                          STS1, 0 = 00_{\rm p})
```

```
CCR, #0BFH ;Interrupts disabled
     AND
     MOV
          I:ICR04,#00H ;Interrupt level 0 (highest)
           I:DDR8,00H
                       ;Sets P82/TIN2 pin to input
     MOV
     CLRB I:CNTE0
                        ;Counter suspended
     MOVW I:TMRLR2, #2710H; Reload value set to 10000 times
     MOVW I:TMCSR2, #0000110001001011B
                         ; Counter operation, rising edge,
                         ; and external output disabled
                         ;One-shot mode selected, interrupt enabled
                         ; Interrupt flag cleared, count started
     VOM
           ILM,#07H
                        ;Set ILM in PS to level 7
           CCR, #40H
                        ; Interrupts enabled
     OR
LOOP:
     Processing by user
      :
          LOOP
     BRA
;-----Interrupt program-----
WARI:
     CLR
          I:UF2
                   ;Interrupt request flag cleared
      :
     Processing by user
      :
     RETI
                        ;Return from interrupt
CODE ENDS
;-----Vector setting------
VECT CSEG ABS=0FFH
     ORG
          00FFB0H
                        ;Set vector to interrupt #19 (13<sub>H</sub>)
     DSL
          WARI
     ORG
          00FFDCH
                        ;Reset vector set
     DSL
           START
     DB
           00H
                       ;Set to single-chip mode
VECT ENDS
     END
           START
```

# CHAPTER 15 WATCH TIMER

This chapter describes the functions and operations of the watch timer.

- 15.1 Overview of Watch Timer
- 15.2 Block Diagram of Watch Timer
- 15.3 Configuration of Watch Timer
- 15.4 Watch Timer Interrupt
- 15.5 Explanation of Operation of Watch Timer
- 15.6 Program Example of Watch Timer

#### 15.1 Overview of Watch Timer

The watch timer is a 15-bit free-run counter that increments in synchronization with the subclock.

- Eight interval times can be selected and an interrupt request can be generated for each interval time.
- An operation clock can be supplied to the oscillation stabilization wait time timer of the subclock and the watchdog timer.
- The subclock is always used as a count clock regardless of the settings of the clock select register (CKSCR).

#### ■ Interval Timer Function

- When the watch timer reaches the interval time set by the interval time select bits (WTC:WTC2 to WTC0), the bit corresponding to the interval time of the watch timer counter overflows (carries) and the overflow flag bit is set (WTC:WTOF = 1).
- When the overflow flag bit is set (WTC:WTOF = 1) with interrupt enabled when an overflow occurs (WTC:WTIE = 1), an interrupt request is generated.
- The interval time of the watch timer can be selected from eight types shown in Table 15.1-1.

Table 15.1-1 Interval Times of Watch Timer

| Subclock Cycle | Interval Time                  |
|----------------|--------------------------------|
|                | 2 <sup>8</sup> /SCLK(31.25 ms) |
|                | 2 <sup>9</sup> /SCLK(62.5 ms)  |
|                | 2 <sup>10</sup> /SCLK(125 ms)  |
| SCI V(122 us)  | 2 <sup>11</sup> /SCLK(250 ms)  |
| SCLK(122 μs)   | 2 <sup>12</sup> /SCLK(500 ms)  |
|                | 2 <sup>13</sup> /SCLK(1.0 s)   |
|                | 2 <sup>14</sup> /SCLK(2.0 s)   |
|                | 2 <sup>15</sup> /SCLK(4.0 s)   |

SCLK: Subclock frequency

The parenthesized values are provided when the subclock operates at 8.192 kHz. Please consider the frequency difference of built-in CR oscillation when you use built-in CR oscillation clock as a sub-clock.

#### **■** Cycle of Clock Supply

The watch timer supplies an operation clock to the oscillation stabilization wait time timer of the subclock and the watchdog timer. Table 15.1-2 shows the cycles of clocks supplied from the watch timer.

Table 15.1-2 Cycle of Clock Supplied from Watch Timer

| Where to Supply Clock                                     | Clock Cycle                    |
|-----------------------------------------------------------|--------------------------------|
| Timer for oscillation stabilization wait time of subclock | 2 <sup>14</sup> /SCLK(4.000 s) |
|                                                           | 2 <sup>10</sup> /SCLK(125 ms)  |
| Week day disease                                          | 2 <sup>13</sup> /SCLK(1.000 s) |
| Watchdog timer                                            | 2 <sup>14</sup> /SCLK(2.000 s) |
|                                                           | 2 <sup>15</sup> /SCLK(4.000 s) |

SCLK: Subclock frequency

The parenthesized values are provided when the subclock operates at 8.192 kHz.

#### Note:

The frequency of the subclock (SCLK) is a value for 2 division/4 division of the clock inputted to the low-speed oscillation pin (X0A and X1A) or the internal CR oscillation clock.

The division ratio is set by the SCDS bit of the PLL/subclock control register (PSCCR).

When using the internal CR oscillation clock, see "CHAPTER 6 CLOCK SUPERVISOR". Please consider the frequency difference of built-in CR oscillation when you use built-in CR oscillation clock as a sub-clock.

## 15.2 Block Diagram of Watch Timer

The watch timer consists of the following blocks:

- Watch timer counter
- Counter clear circuit
- Interval timer selector
- Watch timer control register (WTC)

#### **■** Block Diagram of Watch Timer

Figure 15.2-1 Block Diagram of Watch Timer



The actual interrupt request number of the watch timer is as follows:

Interrupt request number: #27(1B<sub>H</sub>)

Watch timer counter

The watch timer counter is a 15-bit up counter that uses the subclock (SCLK) as a count clock.

Counter clear circuit

The counter-clear circuit clears the watch timer counter.

#### Interval timer selector

The interval timer selector sets the overflow flag bit when the watch timer counter reaches the interval time set in the watch timer control register (WTC).

#### Watch timer control register (WTC)

The watch timer control register (WTC) selects the interval time, clears the watch timer counter, enables or disables an interrupt, checks the overflow (carry) state, and clears the overflow flag bit.

## 15.3 Configuration of Watch Timer

This section explains the registers and interrupt factors of the watch timer.

#### ■ List of Registers and Reset Values of Watch Timer

Figure 15.3-1 List of Registers and Reset Values of Watch Timer



#### ■ Generation of Interrupt Request from Watch Timer

- When the interval time set by the interval time select bits (WTC:WTC2 to WTC0) is reached, the overflow flag bit (WTC:WTOF) is set to "1".
- When the overflow flag bit is set (WTC:WTOF = 1) with interrupt enabled when the watch timer counter overflows (carries) (WTC:WTIE = 1), an interrupt request is generated.

# 15.3.1 Watch Timer Control Register (WTC)

This section explains the functions of the watch timer control register (WTC).

# ■ Watch Timer Control Register (WTC) Figure 15.3-2 Watch Timer Control Register (WTC)



Table 15.3-1 Functions of Watch Timer Control Register (WTC)

|                    | Bit Name                                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|--------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7               | WDCS:<br>Watchdog clock select bit                     | This bit selects the operation clock of the watchdog timer. <main clock="" mode="" or="" pll=""> When set to "0": Selects output of watch timer as operation clock of watchdog timer. When set to "1": Selects output of timebase timer as operation clock of watchdog timer.  <subclock mode=""> Always set this bit to 0 to select the output of the watch timer.  Note:  The watch timer and the timebase timer operate asynchronously. When the WDCS bit is changed from 0 to 1, the watchdog timer may run fast. The watchdog timer must be cleared before and after changing the WDCS bit.</subclock></main> |
| bit6               | SCE:<br>Oscillation stabilization wait<br>time end bit | This bit indicates that the oscillation stabilization wait time of the subclock ends.  When cleared to "0": Subclock in oscillation stabilization wait state  When set to "1": Subclock oscillation stabilization wait time ends  • The oscillation stabilization wait time of the subclock is fixed at 2 <sup>14</sup> /SCLK (SCLK: subclock frequency).                                                                                                                                                                                                                                                          |
| bit5               | WTIE:<br>Overflow interrupt enable bit                 | This bit enables or disables generation of an interrupt request when the watch timer counter overflows (carries).  When set to "0": Interrupt request not generated even at overflow (WTOF=1)  When set to "1": Interrupt request generated at overflow (WTOF = 1)                                                                                                                                                                                                                                                                                                                                                 |
| bit4               | WTOF:<br>Overflow flag bit                             | This bit is set to "1" when the counter value of the watch timer reaches the value set by the interval time select bit.  When an overflow carry occurs (WTOF = 1) with interrupt request enabled (WTIE = 1), an interrupt request is generated.  When set to "0": Clears watch timer counter  When set to "1": No effect  The overflow flag bit is set to "1" when the bit of the watch timer counter corresponding to the interval time set by the interval time select bits (WTC2 to WTC0) overflows (carries).                                                                                                  |
| bit3               | WTR:<br>Watch timer clear bit                          | This bit clears the watch timer counter.  When set to "0": Clears watch timer counter to "0000 <sub>H</sub> ".  When set to "1": No effect  Read: 1 is always read.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit2<br>to<br>bit0 | WTC2, WTC1, WTC0:<br>Interval time select bits         | <ul> <li>These bits set the interval time of the watch timer.</li> <li>When the interval time set by the WTC2 to WTC0 bits is reached, the corresponding bit of the watch timer counter overflows (carries) and the overflow flag bit is set (WTC:WTOF = 1).</li> <li>To set the WTC2 to WTC0 bits, set the WTOF bit to 0.</li> </ul>                                                                                                                                                                                                                                                                              |

# 15.4 Watch Timer Interrupt

When the interval time is reached with the watch timer interrupt enabled, the overflow flag bit is set to "1" and an interrupt request is generated.

## **■** Watch Timer Interrupt

Table 15.4-1 shows the interrupt control bits and interrupt factors of the watch timer.

Table 15.4-1 Interrupt Control Bits of Watch Timer

| Watch Timer                 |                                      |
|-----------------------------|--------------------------------------|
| Interrupt factor            | Interval time of watch timer counter |
| Interrupt request flag bit  | WTC: WTOF(overflow flag bit)         |
| Interrupt factor enable bit | WTC: WTIE                            |

- When the value set by the interval time select bits (WTC2 to WTC0) in the watch timer control register (WTC) is reached, the overflow flag bit in the WTC register is set to "1" (WTC:WTOF = 1).
- When the overflow flag bit is set (WTC:WTOF = 1) with the watch timer interrupt enabled (WTC:WTIE = 1), an interrupt request is generated.
- At interrupt processing, set the WTOF bit to 0 and cancel the interrupt request.

# ■ Watch Timer Interrupt and El<sup>2</sup>OS Transfer Function

- The watch timer does not correspond to the EI<sup>2</sup>OS function.
- For details of the interrupt number, interrupt control register, and interrupt vector address, see "CHAPTER 3 INTERRUPTS".

# 15.5 Explanation of Operation of Watch Timer

The watch timer operates as an interval timer or an oscillation stabilization wait time timer of subclock. It also supplies an operation clock to the watchdog timer.

#### ■ Watch Timer Counter

The watch timer counter continues incrementing in synchronization with the subclock (SCLK) while the subclock (SCLK) is operating.

## Clearing watch timer counter

The watch timer counter is cleared to "0000<sub>H</sub>" when:

- A power-on reset occurs.
- The mode transits to the stop mode.
- The watch timer clear bit (WTR) in the watch timer control register (WTC) is set to "0".

#### Note:

When the watch timer counter is cleared, the interrupts of the watchdog timer and interval timer that use the output of the watch timer counter are affected.

To clear the watch timer by writing zero to the watch timer clear bit (WTR) in the watch timer control register (WTC), set the overflow interrupt enable bit (WTIE) in the WTC register to "0" and set the watch timer to interrupt inhibited state. Before permitting an interrupt, clear the interrupt request issued by writing zero to the overflow flag bit (WTOF) in the WTC register.

#### ■ Interval Timer Function

The watch timer can be used as an interval timer by generating an interrupt at each interval time.

#### Settings when using watch timer as interval timer

Operating the watch timer as an interval timer requires the settings shown in Figure 15.5-1.

Figure 15.5-1 Setting of Watch Timer



- When the value set by the interval time select bits (WTC1, WTC0) in the watch timer control register (WTC) is reached, the overflow flag bit in the WTC register is set to "1" (WTC:WTOF = 1).
- When the overflow flag bit is set (WTC:WTOF = 1) with the overflow interrupt of the watch timer counter enabled (WTC:WTIE = 1), an interrupt request is generated.
- The overflow flag bit (WTC:WTOF) is set when the interval time is reached at the starting point of the timing at which the watch timer is finally cleared.

## Clearing overflow flag bit (WTC:WTOF)

When the mode is switched to the stop mode, the watch timer is used as an oscillation stabilization wait time timer of subclock. The WTOF bit is cleared concurrently with mode switching.

# ■ Setting Operation Clock of Watchdog Timer

The watchdog clock select bit (WDCS) in the watch timer control register (WTC) can be used to set the clock input source of the watchdog timer.

When using the subclock as the machine clock, always set the WDCS bit to 0 and select the output of the watch timer.

## ■ Oscillation Stabilization Wait Time Timer of Subclock

When the watch timer returns from the power-on reset and the stop mode, it functions as an oscillation stabilization wait time timer of subclock.

The subclock oscillation stabilization wait time is fixed at  $2^{14}$  /SCLK (SCLK: subclock frequency).

#### Note:

Please consider the frequency difference of built-in CR oscillation when you use built-in CR oscillation clock as a sub-clock.

# 15.6 Program Example of Watch Timer

This section gives a program example of the watch timer.

# ■ Program Example of Watch Timer

#### Processing specifications

An interval interrupt at  $2^{13}$ /SCLK (SCLK: subclock) is generated repeatedly. The internal time is approximately 1.0 s (when subclock operates at 8.192 kHz).

#### Coding example

```
ICR08 EQU
           0000B8H
                            ; Interrupt control register
                            ; Watch timer control register
WTC
      EQU 0000AAH
WTOF
      EQU
           WTC:4
                            ;Overflow flag bit
;-----Main program-----
CODE
      CSEG
START:
                             ;Stack pointer (SP) already
                             ;initialized
           CCR, #0BFH
                            ; Interrupt disabled
      AND
           I:ICR07,#00H
                            ;Interrupt level 0 (highest)
      VOM
      MOV
           I:WTC,#10100101B
                            ;Interrupt enabled
                             ;Overflow flag cleared
                             ; Watch timer counter cleared,
                             ;2^{13}/SCLK(approx. 1.0 s)
                            ;Set ILM in PS to level 7
           ILM, #07H
      MOV
      OR
           CCR, #40H
                            ;Interrupt enabled
LOOP:
      Processing by user
      BRA
          LOOP
;-----Interrupt program------
WARI:
      CLRB I:WTOF
                            ;Overflow flag cleared
      Processing by user
      RETI
                            ;Return from interrupt processing
CODE
      ENDS
;------Vector setting------
      CSEG ABS=0FFH
VECT
                            ; Reset vector set \#27 (1B<sub>H</sub>)
      ORG 00FF90H
      DSL WARI
```

## CHAPTER 15 WATCH TIMER

ORG 00FFDCH ;Reset vector set

DSL START

00H ;Set to single-chip mode

VECT ENDS

DB

END START

# **CHAPTER 16**

# 8-/16-BIT PPG TIMER

This chapter describes the functions and operations of the 8-/16-bit PPG timer.

- 16.1 Overview of 8-/16-bit PPG Timer
- 16.2 Block Diagram of 8-/16-bit PPG Timer
- 16.3 Configuration of 8-/16-bit PPG Timer
- 16.4 Interrupts of 8-/16-bit PPG Timer
- 16.5 Explanation of Operation of 8-/16-bit PPG Timer
- 16.6 Precautions when Using 8-/16-bit PPG Timer

# 16.1 Overview of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer is a reload timer module with two channels (PPGC and PPGD) that outputs a pulse in any cycle and at any duty ratio. A combination of two channels provides:

- 8-bit PPG output 2-channel independent operation mode
- 16-bit PPG output operation mode
- 8+8-bit PPG output operation mode

The MB90360 series has two 8-/16-bit PPG timers. This section explains the functions of PPGC/D. PPGE/F has the same functions as PPGC/D.

#### **■** Functions of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer consists of four 8-bit reload registers (PRLHC, PRLLC, PRLHD, and PRLLD) and two PPG down counters (PCNTC and PCNTD).

- Individual setting of High and Low widths in output pulse enables an output pulse of any cycle and duty ratio.
- The count clock can be selected from six internal clocks.
- The 8-/16-bit PPG timer can be used as an interval timer by generating an interrupt request at each interval time.
- An external circuit enables the 8-/16-bit PPG timer to be used as a D/A converter.

## ■ Operation Modes of 8-/16-bit PPG Timer

#### 8-bit PPG output 2-channel independent operation mode

The 8-bit PPG output 2-channel independent operation mode causes the 2-channel modules (PPGC and PPGD) to operate as each independent 8-bit PPG timer.

Table 16.1-1 shows the interval times in the 8-bit PPG output 2-channel independent operation mode.

Table 16.1-1 Interval Times in 8-bit PPG Output 2-channel Independent Operation Mode

| Count Clock Cycle            | PPGC, PPGD                                    |                                                |  |
|------------------------------|-----------------------------------------------|------------------------------------------------|--|
| Count Clock Cycle            | Interval Time                                 | Output Pulse Time                              |  |
| 1/φ(41.7 ns)                 | 1/φ to 2 <sup>8</sup> /φ                      | 2/φ to 2 <sup>9</sup> /φ                       |  |
| 2/φ(83.3 ns)                 | 2/φ to 2 <sup>9</sup> /φ                      | $2^2/\phi$ to $2^{10}/\phi$                    |  |
| $2^2/\phi(167 \text{ ns})$   | $2^2/\phi$ to $2^{10}/\phi$                   | $2^3/\phi$ to $2^{11}/\phi$                    |  |
| $2^{3}/\phi(333 \text{ ns})$ | $2^3/\phi$ to $2^{11}/\phi$                   | $2^4/\phi$ to $2^{12}/\phi$                    |  |
| 2 <sup>4</sup> /φ(667 ns)    | $2^4/\phi$ to $2^{12}/\phi$                   | $2^5/\phi$ to $2^{13}/\phi$                    |  |
| 2 <sup>9</sup> /HCLK(128 μs) | 2 <sup>9</sup> /HCLK to 2 <sup>17</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>18</sup> /HCLK |  |

HCLK: Oscillation clock

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 24 MHz.

## 16-bit PPG output operation mode

The 16-bit PPG output operation mode concatenates the 2-channel modules (PPGC and PPGD) to operate as a 16-bit 1-channel PPG timer.

Table 16.1-2 shows the interval times in this mode.

Table 16.1-2 Interval Times in 16-bit PPG Output Operation Mode

| Count clock cycle            | Interval time                    | Output pulse time                              |
|------------------------------|----------------------------------|------------------------------------------------|
| 1/φ(41.7 ns)                 | 1/φ to 2 <sup>16</sup> /φ        | 2/φ to 2 <sup>17</sup> /φ                      |
| 2/φ(83.3 ns)                 | 2/φ to 2 <sup>17</sup> /φ        | $2^2/\phi$ to $2^{18}/\phi$                    |
| $2^2/\phi(167 \text{ ns})$   | $2^{2}/\phi$ to $2^{18}/\phi$    | $2^3/\phi$ to $2^{19}/\phi$                    |
| $2^{3}/\phi(333 \text{ ns})$ | $2^{3}/\phi$ to $2^{19}/\phi$    | $2^4/\phi$ to $2^{20}/\phi$                    |
| 2 <sup>4</sup> /φ(667 ns)    | $2^{4}/\phi$ to $2^{20}/\phi$    | $2^5/\phi$ to $2^{21}/\phi$                    |
| 2 <sup>9</sup> /HCLK(128 μs) | 29/HCLK to 2 <sup>25</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>26</sup> /HCLK |

HCLK: Oscillation clock

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 24 MHz.

φ : Machine clock

φ: Machine clock

## 8+8-bit PPG output operation mode

The 8 + 8-bit PPG output operation mode causes the PPGC of the 2-channel modules to operate as an 8-bit prescaler and the underflow output of the PPGC to operate as the count clock of the PPGD.

Table 16.1-3 shows the interval times in this mode.

Table 16.1-3 Interval Times in 8+8-bit PPG Output Operation Mode

| Count Clock Cycle            | PPGC                                             |                                                    | PPGD                                             |                                                    |
|------------------------------|--------------------------------------------------|----------------------------------------------------|--------------------------------------------------|----------------------------------------------------|
| Count Clock Cycle            | Interval Time                                    | Output Pulse Time                                  | Interval Time                                    | Output Pulse Time                                  |
| 1/φ(41.7 ns)                 | 1/φ to 2 <sup>8</sup> /φ                         | 2/φ to 2 <sup>9</sup> /φ                           | 1/φ to 2 <sup>16</sup> /φ                        | 2/φ to 2 <sup>17</sup> /φ                          |
| 2/φ(83.3 ns)                 | $2/\phi$ to $2^9/\phi$                           | $2^2/\phi$ to $2^{10}/\phi$                        | $2/\phi$ to $2^{17}/\phi$                        | $2^2/\phi$ to $2^{18}/\phi$                        |
| $2^2/\phi(167 \text{ ns})$   | $2^2/\phi$ to $2^{10}/\phi$                      | $2^3/\phi$ to $2^{11}/\phi$                        | $2^2/\phi$ to $2^{18}/\phi$                      | $2^3/\phi$ to $2^{19}/\phi$                        |
| $2^{3}/\phi(333 \text{ ns})$ | $2^3/\phi$ to $2^{11}/\phi$                      | $2^4/\phi$ to $2^{12}/\phi$                        | $2^3/\phi$ to $2^{19}/\phi$                      | $2^4/\phi$ to $2^{20}/\phi$                        |
| 2 <sup>4</sup> /\psi(667 ns) | $2^4/\phi$ to $2^{12}/\phi$                      | $2^5/\phi$ to $2^{13}/\phi$                        | $2^4/\phi$ to $2^{20}/\phi$                      | $2^{5}/\phi$ to $2^{21}/\phi$                      |
| 2 <sup>9</sup> /HCLK(128μs)  | 2 <sup>9</sup> /HCLK to<br>2 <sup>17</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>18</sup> /<br>HCLK | 2 <sup>9</sup> /HCLK to<br>2 <sup>25</sup> /HCLK | 2 <sup>10</sup> /HCLK to 2 <sup>26</sup> /<br>HCLK |

HCLK: Oscillation clock

The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 24 MHz.

φ : Machine clock

# 16.2 Block Diagram of 8-/16-bit PPG Timer

The MB90360 series contains two 8-/16-bit PPG timers (each with 2 channels). One 8-/16-bit PPG timer consists of 8-bit PPG timers with two channels. This section shows the block diagrams for the 8-/16-bit PPG timer C and 8-/16-bit PPG timer D. The PPGE has the same function as the PPGC, and PPGF has the same function as PPGD.

#### **■** Channels and PPG Pins of PPG Timers

Figure 16.2-1 shows the relationship between the channels and the PPG pins of the 8-/16-bit PPG timers in the MB90360 series.



Figure 16.2-1 Channels and PPG Pins of PPG Timers

#### 16.2.1 Block Diagram for 8-/16-bit PPG Timer C

The 8-/16-bit PPG timer C consists of the following blocks.

# ■ Block Diagram of 8-/16-bit PPG Timer C

Figure 16.2-2 Block Diagram of 8-/16-bit PPG Timer C



#### Details of pins in block diagram

Table 16.2-1 lists the actual pin names and interrupt request numbers of the 8-/16-bit PPG timer.

Table 16.2-1 Pins and Interrupt Request Numbers in Block Diagram

| Channel | Output Pin |            | Interrupt Request<br>Number |  |
|---------|------------|------------|-----------------------------|--|
|         | PPG:REV=0  | PPG:REV=1  | Number                      |  |
| PPGC    | P66 / PPGC | P22 / PPGD | #23 (17 <sub>H</sub> )      |  |
| PPGD    | P22 / PPGD | P66 / PPGC | #23 (17H)                   |  |
| PPGE    | P67/ PPGE  | P23 / PPGF | #24 (18 <sub>H</sub> )      |  |
| PPGF    | P23/ PPGF  | P67 / PPGE | π2+ (10H)                   |  |

## PPG operation mode control register C (PPGCC)

This register enables or disables operation of the 8-/16-bit PPG timer, pin output and an underflow interrupt. It also indicates the occurrence of an underflow.

#### PPGC/D count clock select register (PPGCD)

This register sets the count clock of the 8-/16-bit PPG timer and switching the output pin between PPGC and PPGD.

## PPGC reload registers (PRLHC, PRLLC)

These registers set the High width or Low width of the output pulse. The values set in these registers are reloaded to the PPGC down counter (PCNTC) when the 8-/16-bit PPG timer is started.

#### PPGC down counter (PCNTC)

This counter is an 8-bit down counter that alternately reloads the values set in the PPGC reload registers (PRLHC and PRLLC) to decrement. When an underflow occurs, the pin output is inverted. The 2-channel PPG down counters (PPGC and PPGD) can also be concatenated for use as a single-channel 16-bit PPG down counter.

#### PPGC temporary buffer (PRLBHC)

This buffer prevents deviation of the output pulse width caused at writing to the PPG reload registers (PRLHC and PRLLC). This buffer stores the PRLHC value temporarily and enables it in synchronization with the timing of writing to the PRLLC.

#### Reload register L/H selector

This selector detects the current pin output level to select which register value, Low reload register (PRLLC) or High reload register (PRLHC), should be reloaded to the PPGC down counter.

#### Count clock selector

This selector selects the count clock to be inputted to the PPGC down counter from five frequency-divided clocks of the machine clock or the frequency-divided clocks of the timebase timer.

#### PPG output control circuit

This circuit inverts the pin output level and the output when an underflow occurs.

#### 16.2.2 Block Diagram of 8-/16-bit PPG Timer D

The 8-/16-bit PPG timer D consists of the following blocks.

# ■ Block Diagram of 8-/16-bit PPG Timer D

Figure 16.2-3 Block Diagram of 8-/16-bit PPG Timer D



#### Details of pins in block diagram

Table 16.2-2 lists the actual pin names and interrupt request numbers of the 8-/16-bit PPG timer.

Table 16.2-2 Pins and Interrupt Request Numbers in Block Diagram

| Channel | Output Pin |            | Interrupt Request Number |
|---------|------------|------------|--------------------------|
|         | PPG:REV=0  | PPG:REV=1  | Number                   |
| PPGC    | P66 / PPGC | P22 / PPGD | #23 (17 <sub>H</sub> )   |
| PPGD    | P22 / PPGD | P66 / PPGC | #23 (17Н)                |
| PPGE    | P67/ PPGE  | P23 / PPGF | #24 (18 <sub>H</sub> )   |
| PPGF    | P23/ PPGF  | P67 / PPGE | π2¬ (10Н)                |

## PPG operation mode control register D (PPGCD)

This register sets the operation mode of the 8-/16-bit PPG timer, enables or disables the operation of the 8-/16-bit PPG timer D, the pin output and an underflow interrupt, and also indicates the generation of an underflow.

#### PPGC/D count clock select register (PPGCD)

This register sets the count clock of the 8-/16-bit PPG timer.

#### PPGD reload registers (PRLHD, PRLLD)

These registers set the High width or Low width of the output pulse. The values set in these registers are reloaded to the PPGD down counter (PCNTD) when the 8-/16-bit PPG timer D is started.

#### PPGD down counter (PCNTD)

This counter is an 8-bit down counter that alternately reloads the values set in the PPGD reload registers (PRLHD and PRLLD) to decrement. When an underflow occurs, the pin output is inverted. The 2-channel PPG down counters (PPGC and PPGD) can also be connected for use as a single-channel 16-bit PPG down counter.

#### PPGD temporary buffer (PRLBHD)

This buffer prevents deviation of the output pulse width caused at writing to the PPG reload registers (PRLHD and PRLLD). It stores the PRLHD value temporarily and enables it in synchronization with the timing of writing to the PRLLD.

#### Reload register L/H selector

This selector detects the current pin output level to select which register value, Low reload register (PRLLD) or High reload register (PRLHD), should be reloaded to the PPGD down counter.

#### Count clock selector

This selector selects the count clock to be inputted to the PPGD down counter from five frequency-divided clocks of the machine clock or the frequency-divided clocks of the timebase timer.

#### PPG output control circuit

This circuit inverts the pin output level and the output when an underflow occurs.

# 16.3 Configuration of 8-/16-bit PPG Timer

This section explains the pins, registers and interrupt factors of the 8-/16-bit PPG timer.

## ■ Pins of 8-/16-bit PPG Timer

The pins of the 8-/16-bit PPG timer serve as general-purpose I/O ports. Table 16.3-1 indicates the pin functions and pin settings required to use the 8-/16-bit PPG timer.

Table 16.3-1 Pins of 8-/16-bit PPG Timer

| Channel | Pin Name               | Pin Function                                                               | Pin Setting Required for Use of 8-/16-bit<br>PPG Timer                                                                                                                    |
|---------|------------------------|----------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PPGC    | P66 /<br>AN6 /<br>PPGC | General-purpose I/O port,<br>A/D converter analog input 6/<br>PPG output C | <ul> <li>Analog input enable register:<br/>setting to disable(ADER6:ADE6=0)</li> <li>PPG operating mode control register:<br/>pin output enable (PPGCC:PE0=1)</li> </ul>  |
| PPGD    | P22 /<br>PPGD          | General-purpose I/O port,<br>PPG output D                                  | PPG operating mode control register :     pin output enable (PPGCD:PE1=1)                                                                                                 |
| PPGE    | P67 /<br>AN7 /<br>PPGE | General-purpose I/O port,<br>A/D converter analog input 7/<br>PPG output E | <ul> <li>Analog input enable register:<br/>setting to disable (ADER6:ADE7=0)</li> <li>PPG operating mode control register:<br/>pin output enable (PPGCE:PE0=1)</li> </ul> |
| PPGF    | P23 /<br>PPGF          | General-purpose I/O port,<br>PPG output F                                  | PPG operating mode control register :     pin output enable (PPGCF:PE1=1)                                                                                                 |

# ■ List of Registers and Reset Values of 8-/16-bit PPG Timer

Figure 16.3-1 List of Registers and Reset Values of 8-/16-bit PPG Timer



#### ■ Generation of Interrupt Request from 8-/16-bit PPG Timer

In the 8-/16-bit PPG timer, the underflow generation flag bits in the PPG operation mode control registers (PPGCn:PUFn, PPGCm:PUFm) are set to "1" when an underflow occurs. If the underflow interrupts of channels causing an underflow are enabled (PPGCn: PIE0=1, PPGCm: PIE1=1), an underflow interrupt request is generated to the interrupt controller.

# 16.3.1 PPGC Operation Mode Control Register (PPGCC)

The PPGC operation mode control register (PPGC0) provides the following settings for the operation of 8-/16-bit PPG timer C:

- Enabling or disabling operation of 8-/16-bit PPG timer C
- Switching between pin functions (enabling or disabling pulse output)
- Enabling or disabling underflow interrupt
- Setting underflow interrupt request flag

This section explains the PPGCC function only. The PPGCE has the same function as the PPGCC, and the 8-/16-bit PPPG timer C and E is set.

## **■ PPGC Operation Mode Control Register (PPGCC)**



292

**Table 16.3-2 Functions of PPGC Operation Mode Control Register (PPGCC)** 

| Bit Name     |                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|--------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7         | PEN0:<br>PPG0 operation enable bit         | This bit enables or disables the count operation of the 8-/16-bit PPG timer C.  When set to "0": Count operation disabled When set to "1": Count operation enabled  • When the count operation is disabled (PEN0=0), and the pulse output is enabled (PE0=1), the output is held at a Low level.                                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit6         | Undefined bit                              | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bit5         | PE0:<br>PPG0 pin output enable bit         | This bit switches between PPGC pin functions and enables or disables the pulse output.  When set to "0": PPGC pin functions as general-purpose I/O port. The pulse output is disabled.  When set to "1": PPGC pin functions as PPGC output pin. The pulse output is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| bit4         | PIE0:<br>Underflow interrupt enable<br>bit | This bit enables or disables an interrupt.  When set to "0": No interrupt request generated even at underflow (PUF0 = 1).  When set to "1": Interrupt request generated at underflow (PUF0 = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| bit3         | PUF0:<br>Underflow generation flag<br>bit  | <ul> <li>8-bit PPG output 2-channel independent operation mode, 8+8-bit PPG output operation mode:  When the value of the PPGC down counter is decremented from "00<sub>H</sub>" to "FF<sub>H</sub>", an underflow occurs (PUF0 = 1).</li> <li>16-bit PPG output operation mode:  When the values of the PPGC and PPGD down counters are decremented from "0000<sub>H</sub>" to "FFFF<sub>H</sub>", an underflow occurs (PUF0 = 1).</li> <li>When an underflow occurs (PUF0 = 1) with an underflow interrupt enabled (PIE0 = 1), an interrupt request is generated.</li> <li>When set to "0": Clears counter</li> <li>When set to "1": No effect</li> <li>Read by read modify write instructions: 1 is read.</li> </ul> |
| bit2<br>bit1 | Undefined bits                             | Write: No effect Read: The value is undefined.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| bit0         | Reserved: Reserved bit                     | Always set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

# 16.3.2 PPGD Operation Mode Control Register (PPGCD)

The PPGD operation mode control register provides the following settings about operation of 8-/16-bit PPG timer D:

- Enabling or disabling operation of 8-/16-bit PPG timer D
- Switching between pin functions (enabling or disabling pulse output)
- Enabling or disabling underflow interrupt
- Setting underflow interrupt request flag
- Setting the operation mode of the 8-/16-bit PPG timer D and C

This section explains the PPGCD function only. The PPGCF has the same function as the PPGCD, and the 8-/16-bit PPG timer F is set.

# **■ PPGD Operation Mode Control Register (PPGCD)**



Table 16.3-3 Functions of PPGD Operation Mode Control Register (PPGCD)

|               | Bit name                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|---------------|--------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15         | PEN1:<br>PPG1 operation enable bit         | This bit enables or disables the count operation of the 8-/16-bit PPG timer D.  When set to "0": Count operation disabled  When set to "1": Count operation enabled  • When the count operation is disabled (PEN1 = 0), and the pulse output is enabled (PE1=1), the output is held at a Low level.                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bit14         | Undefined bit                              | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit13         | PE1:<br>PPG1 Pin output enable bit         | This bit switches between PPGD pin functions and enables or disables the pulse output.  When set to "0": PPGD pin functions as general-purpose I/O port. The pulse output is disabled.  When set to "1": PPGD pin functions as PPGD output pin. The pulse output is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| bit12         | PIE1:<br>Underflow interrupt enable<br>bit | This bit enables or disables an interrupt.  When set to "0": No interrupt request is generated even at underflow (PUF1 = 1)  When set to "1": Interrupt request is generated at underflow (PUF1 = 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| bit11         | PUF1:<br>Underflow generation flag<br>bit  | <ul> <li>8-bit PPG output 2-channel independent operation mode, 8+8-bit PPG output operation mode: When the value of the PPGD down counter is decremented from "00<sub>H</sub>" to "FF<sub>H</sub>", an underflow occurs (PUF1 = 1).</li> <li>16-bit PPG output operation mode: When the values of the PPGC and PPGD down counters are decremented from "0000<sub>H</sub>" to "FFFF<sub>H</sub>", an underflow occurs (PUF1 = 1).</li> <li>• When an underflow occurs (PUF1 = 1) with an underflow interrupt request enabled (PIE1 = 1), an interrupt request is generated.</li> <li>When set to "0": Clears counter</li> <li>When set to "1": No effect</li> <li>Read by read modify write instructions: 1 is read.</li> </ul> |
| bit10<br>bit9 | MD1, MD0:<br>Operation mode select bits    | These bits set the operation mode of the 8-/16-bit PPG timer.  [Any mode other than 8-bit PPG output 2-channel independent operation mode]  • Use a word instruction to set the PPG operation enable bits (PEN0 and PEN1) at one time.  • Do not set operation of only one of the two channels (PEN1 = 0/PEN0 = 1 or PEN1 = 1/PEN0 = 0).  Note:  Do not set the MD1 and MD0 bits to "10 <sub>B</sub> ".                                                                                                                                                                                                                                                                                                                         |
| bit8          | Reserved: Reserved bit                     | Always set this bit to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |

# 16.3.3 PPGC/D Count Clock Select Register (PPGCD)

The PPGC/D count clock select register selects the count clock of the 8-/16-bit PPG timers C and D and the output pin.

This section explains the PPGCD function only. The PPGEF has the same function as the PPGCD, and the 8-/16-bit PPG timers E and F are set.

## ■ PPGC/D Count Clock Select Register (PPGCD)

Figure 16.3-4 PPGC/D Count Clock Select Register (PPGCD) Address: 00004A<sub>H</sub> chD PPGCD Reset value REV PCS1 PCS0 PCM2 PCM1 PCM0 00000X0B Other channel: 00004E<sub>H</sub> R/W R/W R/W R/W R/W R/W R/W chF PPGEF bit 0 REV PPG output pin select bit 0 Output pulse from standard output pin Switch output pin between PPGn and PPGm 1 bit 4 bit 3 bit 2 PPGC PCM2 PCM1 PCM0 count clock select bits 1/φ(41.7 ns) 0 0 0 0 0 2/\psi(83.3 ns) 0 1 0  $2^2/\phi(167 \text{ ns})$ 0 1  $2^{3}/\phi(333 \text{ ns})$ 1 1 0 0  $2^4/\phi(667 \text{ ns})$ 0 Setting disable 1 1 1 0 Setting disable 1 1 1 29/HCLK(128 µs) bit 7 bit 6 bit 5 PPGD PCS2 PCS1 PCS0 count clock select bits 0 0 0 1/\psi(41.7 ns) 0 0 1 2/\psi(83.3 ns) R/W: Read/Write 0 1 0  $2^2/\phi(167 \text{ ns})$ Χ : Indeterminate 0 1 1  $2^{3}/\phi(333 \text{ ns})$ : Undefined 1 0 0  $2^4/\phi$ (667 ns) : Reset value 0 Setting disable HCLK: Oscillation clock 1 1 0 Setting disable : Machine clock frequency 1 1 29/HCLK(128 µs) The parenthesized values are provided when the oscillation clock operates at 4 MHz and the machine clock operates at 24 MHz. n = C, Em = n+1

Table 16.3-4 Functions of PPGC/D Count Clock Select Register (PPGCD)

| Bit Name           |                                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|--------------------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit7<br>to<br>bit5 | PCS2 to PCS0:<br>PPGD count clock select bits | <ul> <li>These bits set the count clock of the 8-/16-bit PPG timer D.</li> <li>The count clock can be selected from five frequency-divided clocks of the machine clock and the frequency-divided clocks of the timebase timer.</li> <li>The settings of the PPGD count clock select bits (PCS2 to PCS0) are enabled only in the 8-bit PPG output 2-channel independent mode (PPGCD: MD1, MD0="00<sub>B</sub>").</li> </ul> |  |
| bit4<br>to<br>bit2 | PCM2 to PCM0:<br>PPGC count clock select bits | These bits set the count clock of the 8-/16-bit PPG timer C.  • The count clock can be selected from five frequency-divided clocks of the machine clock and the frequency-divided clocks of the timebase timer.                                                                                                                                                                                                            |  |
| bit1               | Undefined bit                                 | Read: The value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                                                             |  |
| bit0               | REV:<br>PPG output pin select bit             | This bit switches the output pin in the 8-/16-bit PPG timer C and D.  When set to "0": Output from the standard output pin.  PPGC → PPGC output pin  PPGD → PPGD output pin  When set to "1": Switch the output pin.  PPGC → PPGD output pin  PPGD → PPGC output pin                                                                                                                                                       |  |

#### PPG Reload Registers (PRLLC/PRLHC, PRLLD/PRLHD) 16.3.4

The value (reload value) from which the PPG down counter starts counting is set in the PPG reload registers, which are an 8-bit register at Low level and an 8-bit register at High level.

This section explains the function of PRLLC/PRLHC and PRLLD/PRLHD only. The PRLLE/PRLHE, PRLLF/PRLHF have the same function as the PRLLC/PRLHC, and the 8-/ 16-bit PPG timers E, F are set.

Figure 16.3-5 PPG Reload Registers (PRLLC/PRLHC, PRLLD/PRLHD)

# ■ PPG Reload Registers (PRLLC/PRLHC, PRLLD/PRLHD)

Address: bit15 bit14 bit13 bit12 bit11 bit10 bit9 bit8 Reset value chC PRLHC 007919<sub>H</sub> chD PRLHD 00791B<sub>H</sub> D15 D14 D13 D12 D11 D10 D9 D8 XXXXXXXXB Other channel: R/W R/W R/W R/W R/W R/W R/W R/W 00791D<sub>H</sub> chE PRLHE chF PRLHF 00791F<sub>H</sub>

bit6 bit5 bit2 bit7 bit4 bit3 bit1 bit0 Address: Reset value 007918<sub>H</sub> chC PRLLC D7 D2 D6 D5 D4 D3 D1 D0 chD PRLLD 00791A<sub>H</sub> XXXXXXXXB Other channel: R/W R/W R/W R/W R/W R/W R/W R/W 00791C<sub>H</sub> chE PRLLE chF PRLLF

R/W: Read/Write : Undefined

00791E<sub>H</sub>

Table 16.3-5 indicates the functions of the PPG reload registers.

Table 16.3-5 Functions of PPG Reload Registers

| Function                                | 8-/16-bit PPG Timer C | 8-/16-bit PPG Timer D |
|-----------------------------------------|-----------------------|-----------------------|
| Retains reload value on Low-level side  | PRLLC                 | PRLLD                 |
| Retains reload value on High-level side | PRLHC                 | PRLHD                 |

#### Notes:

- In the 16-bit PPG output operation mode (PPGCD: MD1, MD0="11<sub>B</sub>"), use a long-word instruction to set the PPG reload registers or the word instruction to set the PPGC and PPGD in this order.
- In the 8 + 8-bit PPG output operation mode (PPGCD: MD1, MD0="01<sub>R</sub>"), set the same value in both the Low-level and High-level PPG reload registers (PRLLC/PRLHC) of the 8-/16-bit PPG timer C. Setting a different value in the Low-level and High-level PPG reload registers may cause the 8-/16-bit PPG timer D to have different PPG output waveforms at each clock cycle.

# 16.4 Interrupts of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer can generate an interrupt request when the PPG down counter underflows. It also not corresponds to the El<sup>2</sup>OS.

## ■ Interrupts of 8-/16-bit PPG Timer

Table 16.4-1 shows the interrupt control bits and interrupt factor of the 8-/16-bit PPG timer.

Table 16.4-1 Interrupt Control Bits of 8-/16-bit PPG Timer

|                              | PPGn                           | PPGm                           |
|------------------------------|--------------------------------|--------------------------------|
| Interrupt request flag bit   | PPGCn: PUF0                    | PPGCm: PUF1                    |
| Interrupt request enable bit | PPGCn: PIE0                    | PPGCm: PIE1                    |
| Interrupt factor             | Underflow in PPGn down counter | Underflow in PPGm down counter |

Note:  $n = C, E \quad m = n + 1$ 

#### [8-bit PPG output 2-channel independent operation mode or 8 + 8-bit PPG output operation mode]

- In the 8-bit PPG output 2-channel independent operation mode or the 8 + 8-bit PPG output operation mode, the PPGn and PPGm timers can generate an interrupt independently.
- When the value of the PPGn or PPGm down counter is decremented from "00<sub>H</sub>" to "FF<sub>H</sub>", an underflow occurs. When an underflow occurs, the underflow generation flag bit in the channel causing an underflow is set (PPGCn: PUF0=1 or PPGCm: PUF1=1).
- If an interrupt request from the channel that causes an underflow is enabled (PPGCn: PIE0=1 or PPGCm: PIE1=1), an interrupt request is generated.

#### [16-bit PPG output operation mode]

- In the 16-bit PPG output operation mode, when the values of the PPGn and PPGm down counters are decremented from "0000<sub>H</sub>" to "FFFF<sub>H</sub>", an underflow occurs. When an underflow occurs, the underflow generation flag bits in the two channels are set at one time (PPGCn: PUF0=1 or PPGCm: PUF1=1).
- When an underflow occurs with either of the two channel of the interrupt requests enabled (PPGCn: PIE1=0, PPGCm: PIE1=1 or PPGCn: PIE0=1, PPGCm: PIE0=0), an interrupt request is generated.
- To prevent duplication of interrupt requests, disable either of the two channel of the underflow interrupt enable bits in advance (PPGCn: PIE0=0, PPGCm: PIE1=1 or PPGCn: PIE0=1, PPGCm: PIE1=0).
- When the two channels of the underflow generation flag bits are set (PPGCn: PUF0=1 and PPGCm: PUF1=1), clear the two channels at the same time.

#### ■ Interrupt of 8-/16-bit PPG Timer

For details of the interrupt number, interrupt control register, and interrupt vector address, see "CHAPTER 3 INTERRUPTS".

# 16.5 Explanation of Operation of 8-/16-bit PPG Timer

The 8-/16-bit PPG timer outputs a pulse width at any frequency and at any duty ratio continuously.

# ■ Operation of 8-/16-bit PPG Timer

#### Output operation of 8-/16-bit PPG timer

- The 8-/16-bit PPG timer has two (Low-level and High-level) 8-bit reload registers (PRLLn/PRLHn and PRLLm/PRLHm) for per channel.
- The values set in the 8-bit reload registers (PRLLn/PRLHn and PRLLm/PRLHm) are reloaded alternately to the PPG down counters (PCNTn and PCNTm).
- After reloading the values in the PPG down counters, decrementing is performed in synchronization
  with the count clocks set by the PPG count clock select bits (PPGnm: PCM2 to PCM0 and PCS2 to
  PCS0).
- If the values set in the reload registers are reloaded to the PPG down counters when an underflow occurs, the pin output is inverted.

Figure 16.5-1 shows the output waveform of the 8-/16-bit PPG timer.



Figure 16.5-1 Output Waveform of 8-/16-bit PPG Timer

#### Operation modes of 8-/16-bit PPG timer

As long as the operation of the 8-/16-bit PPG timer is enabled (PPGCn: PEN0=1, PPGCm: PEN1=1), a pulse waveform is outputted continuously from the PPG output pin. A pulse width of any frequency and duty ratio can be set.

The pulse output of the 8-/16-bit PPG timer is not stopped until operation of the 8-/16-bit PPG timer is stopped (PPGCn: PEN0=0, PPGCm: PEN1=0).

- 8-bit PPG output 2-channel independent operation mode
- 16-bit PPG output operation mode
- 8 + 8-bit PPG output operation mode

Note: n = C, Em = n+1

# 16.5.1 8-bit PPG Output 2-channel Independent Operation Mode

In the 8-bit PPG output 2-channel independent operation mode, the 8-/16-bit PPG timer is set as an 8-bit PPG timer with two independent channels. PPG output operation and interrupt request generation can be performed independently for each channel.

# ■ Setting for 8-bit PPG Output 2-channel Independent Operation Mode

Operating the 8-/16-bit PPG timer in the 8-bit PPG output 2-channel independent operation mode requires the setting shown in Figure 16.5-2.

Figure 16.5-2 Setting for 8-bit PPG Output 2-channel Independent Operation Mode bit15 13 12 11 10 9 bit8 bit7 5 bit0 Re-Re-PUF1 MD1 MD0 served PE0 PPGCm/PPGCn PEN1 PE1 PEN0 PIE0 PUF0 PIE1

served 0 0 1 0 0 0 1 1 0 0 0 1 (Reserved area) PCS2 PCS1 PCS0 PCM2 PCM1 PCM0 REV **PPGnm** 0 0 0 0 0 0

PRLHn/PRLLn PPGn set High level side reload values. PPGn set Low level side reload values.

PRLHm/PRLLm | PPGm set High level side reload values. | PPGm set Low level side reload values.

Used bitUndefined bit

1 : Set 1 0 : Set 0

Note: n = C, E m = n + 1

#### Note:

Use the word instruction to set both High-level and Low-level PPG reload registers (PRLLn/PRLHn and PRLLm/PRLHm) at the same time.

- Operation in 8-bit PPG output 2-channel independent operation mode
  - The 8-bit PPG timer with two channels performs an independent PPG operation.
  - When the pin output is enabled (PPGCn: PEC=1, PPGCm: PED=1), if the PPG output pin selection is set to standard (PPGnm:REV=0), the PPGn pulse wave is outputted from the PPGn pin and the PPGm pulse wave is outputted from the PPGm pin. When the PPG output pin is switched (PPGnm: REV=1), the PPGm pulse wave is outputted from the PPGn pin and the PPGn pulse wave is outputted from the PPGm pin.
  - When the reload value is set in the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) to enable the operation of the PPG timer (PPGCn: PENC=1, PPGCm: PEND=1), the PPG down counter of the enabled channel starts counting.
  - To stop the count operation of the PPG down counter, disable the operation of the PPG timer of the channel to be stopped (PPGCn: PENC=0, PPGCm: PEND=0). The count operation of the PPG down counter is stopped and the output of the PPG output pin is held at a Low level.
  - When the PPG down counter of each channel underflows, the reload values set in the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) are reloaded to the PPG down counter that underflows.
  - When an underflow occurs, the underflow generation flag bit in the channel that causes an underflow is set (PPGCn: PUFC=1, PPGCm: PUFD=1). If an interrupt request is enabled at the channel that causes an underflow (PPGCn: PIEC=1, PPGCm: PIED=1), the interrupt request is generated.

## Output waveform in 8-bit PPG output 2-channel independent operation mode

The High and Low pulse widths to be outputted are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle. For example, if the value in the PPG reload register is  $"00_H"$ , the pulse width has one count clock cycle, and if the value is "FF<sub>H</sub>", the pulse width has 256 count clock cycles.

The equations for calculating the pulse width are shown below:

 $P_L = T \times (L+1)$ 

 $P_H=T\times (H+1)$ 

P<sub>L</sub>: Low width of output pulse

P<sub>H</sub>: High width of output pulse

L: Values of 8 bits in PPG reload register (PRLLn or PRLLm)

H: Values of 8 bits in PPG reload register (PRLHn or PRLHm)

T: Count clock cycle

Figure 16.5-3 shows the output waveform in the 8-bit PPG output 2-channel independent operation mode.

Operating start

Operating stop

PPG operating enable bit (PEN)

PPG output pin

L: Value of PPG reload register (PRLL)
H: Value of PPG reload register (PRLH)
T: Count clock cycle

Note: n = C, E
m = n + 1

303

# 16.5.2 16-bit PPG Output Operation Mode

In the 16-bit PPG output operation mode, the 8-/16-bit PPG timer is set as a 16-bit PPG timer with one channel.

## ■ Setting for 16-bit PPG Output Operation Mode

Operating the 8-/16-bit PPG timer in the 16-bit PPG output operation mode requires the setting shown in Figure 16.5-4.

1 bit15 13 12 11 10 bit8 bit7 3 bit0 MD1 MD0 served PEN1 PE1 PIE1 PUF1 PEN0 PE0 PIE0 PUF0 PPGCm/PPGCn served 1 0 0 0 PCS2 PCS1 PCS0 PCM2 PCM1 PCM0 REV **PPGnm** (Reserved area) 0 PPGn set high level side reload values of lower PPGn set low level side reload values of lower PRLHn/PRLLn PPGm set high level side reload values of upper PPGm set low level side reload values of upper PRLHm/PRLLm (i): Used bit X: Unused bit - : Undefined bit 1 : Set 1 0 : Set 0 Note: n = C, Em = n + 1

Figure 16.5-4 Setting for 16-bit PPG Output Operation Mode

#### Note:

Use a long-word instruction to set the values in the PPG reload registers or a word instruction to set the PPGn and PPGm (PRLLn --> PRLLm or PRLHn --> PRLHm) in this order.

#### Operation in 16-bit PPG output operation mode

- When either PPGn pin output or PPGm pin output is enabled (PPGCn:PEC=1, PPGCm: PED=1), the same pulse wave is outputted from both the PPGn and PPGm pins.
- When the reload value is set in the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) to enable operation of the PPG timer (PPGCn:PENC=1 and PPGCm: PEND=1), the PPG down counters start counting as 16-bit down counters (PCNTn + PCNTm).
- To stop the count operation of the PPG down counters, disable the operation of the PPG timers of both channels (PPGCn: PENC=0 and PPGCm: PEND=0). The count operation of the PPG down counters is stopped and the output of the PPG output pin is held at a Low level.
- If the PPGm down counter underflows, the reload values set in the PPGn and PPGm reload registers (PRLLn/PRLHn, PRLLm/PRLHm) are reloaded simultaneously to the PPG down counters (PCNTn + PCNTm).
- When an underflow occurs, the underflow generation flag bits in both channels are set simultaneously (PPGCn:PUFC=1, PPGCm:PUFD=1). If an interrupt request is enabled at either channel (PPGCn: PIEC=1, PPGCm: PIED=1), an interrupt request is generated.

#### Notes:

- In the 16-bit PPG output operation mode, the underflow generation flag bits in the two channels are set simultaneously when an underflow occurs (PPGCn: PUFC=1 and PPGCm: PUFD=1). To prevent duplication of interrupt requests, disable either of the underflow interrupt enable bits in the two channels (PPGCn:PIEC=0, PPGCm:PIED=1 or PPGCn:PIEC=1, PPGCm:PIED=0).
- If the underflow generation flag bits in the two channels are set (PPGCn: PUFC=0 and PPGCm: PUFD=0), clear the two channels at the same time.

Note: n = C, Em = n+1

#### Output waveform in 16-bit PPG output operation mode

The High and Low pulse widths to be outputted are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle. For example, if the value in the PPG reload register is  $"0000_{\rm H}"$ , the pulse width has one count clock cycle, and if the value is "FFFF<sub>H</sub>", the pulse width has 65,536 count clock cycles.

The equations for calculating the pulse width are shown below:

 $PL=T \times (L+1)$ 

 $PH=T \times (H+1)$ 

PL: Low width of output pulse

PH: High width of output pulse

L: Values of 16 bits in PPG reload register (PRLLn+PRLLm)

H: Values of 16 bits in PPG reload register (PRLHn+PRLHm)

T: Count clock cycle

Figure 16.5-5 shows the output waveform in the 16-bit PPG output operation mode.



# 16.5.3 8+8-bit PPG Output Operation Mode

In the 8 + 8-bit PPG output operation mode, the 8-/16-bit PPG timer is set as an 8-bit PPG timer. The PPGC operates as an 8-bit prescaler and the PPG operates using the PPG output of the PPGC as a clock source.

## ■ Setting for 8+8-bit PPG Output Operation Mode

Operating the 8-/16-bit PPG timer in the 8+8-bit PPG output operation mode requires the setting shown in Figure 16.5-6.

13 12 11 10 9 bit8 bit7 bit0 Re-PPGCm/PPGCn PEN1 PE1 PIE1 PUF1 MD1 MD0 PEN0 PE0 PIE0 PUF0 serve (Reserved area) **PPGnm** PCS2 PCS1 PCS0 PCM2 PCM1 PCM0 REV × PPGn set High level side reload values. PPGn set Low level side reload values. PRLHn/PRLLn PPGm set High level side reload values. PRLHm/PRLLm PPGm set Low level side reload values. Used bit X: Unused bit : Undefined bit 1 : Set 1 0 : Set 0 Note: n = C, Em = n + 1

Figure 16.5-6 Setting for 8+8-bit PPG Output Operation Mode

#### Note:

Use the word instruction to set both High-level and Low-level PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) at the same time.

#### Operation in 8+8-bit PPG output operation mode

- The PPGn operates as the prescaler of the PPGm timer and the PPGm operates using the PPGn output as a clock source.
- When the pin output is enabled (PPGCn: PE0=1, PPGCm: PE1=1) if PPG output pin selection is set to standard (PPGnm:REV=0), PPGn pulse wave is outputted from the PPGn pin and the PPGm pulse wave is outputted from the PPGm pin. When the PPG output pin is switched (PPGnm:REV=1), the output pins PPGn and PPGm are switched.
- When the reload value is set in the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) to enable
  operation of the PPG timer (PPGCn:PEN0=1 and PPGCm: PEN1=1), the PPG down counter starts
  counting.
- To stop the count operation of the PPG down counters, disable the operation of the PPG timers of both channels (PPGCn: PEN0=0 and PPGCm: PEN1=0). The count operation of the PPG down counters is stopped and the output of the PPG output pin is held at a Low level.
- If the PPG down counter of each channel underflows, the reload values set in the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) are reloaded to the PPG down counter that underflows.
- When an underflow occurs, the underflow generation flag bit in the channel that causes an underflow (PPGCn:PUF0=1, PPGCm:PUF1=1) is set. If an interrupt request is enabled at the channel that causes an underflow (PPGCn: PIE0=1, PPGCm: PIE1=1), an interrupt request is generated.

#### Notes:

- Do not operate PPGm (PPGCm:PEN1 = 1) when PPGn is stopped (PPGCn:PEN0 = 0).
- It is recommended to set the same value in both Low-level and High-level PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm).

Note: n = C, Em = n+1

# Output waveform in 8+8-bit PPG output operation mode

The High and Low pulse widths to be outputted are determined by adding 1 to the value in the PPG reload register and multiplying it by the count clock cycle.

The equations for calculating the pulse width are shown below:

 $PL=T \times (Ln+1) \times (Lm+1)$ 

 $PH=T \times (Hn+1) \times (Hm+1)$ 

PL: Low width of output pulse of PPGm pin

PH: High width of output pulse of PPGm pin

L<sub>n</sub>: Values of 8 bits in PPG reload register (PRLLn)

H<sub>n</sub>: Values of 8 bits in PPG reload register (PRLHn)

L<sub>m</sub>: Values of 8 bits in PPG reload register (PRLLm)

H<sub>m</sub>: Values of 8 bits in PPG reload register (PRLHm)

T: Count clock cycle

Figure 16.5-7 shows the output waveform in the 8+8-bit PPG output operation mode.

Figure 16.5-7 Output Waveform in 8+8-bit PPG Output Operation Mode Operation stop Operation start PPG operation enable bit (PENn, PENm)  $T \times (L_0 + 1) \quad T \times (H_0 + 1)$ PPGn output pin PPGm output pin  $T \times (L_0 + 1) \times (L_1 + 1)$  $T \times (H_0 + 1) \times (H_1 + 1)$ Ln : Values of 8 bits in PPG reload register (PRLLn) Hn: Values of 8 bits in PPG reload register (PRLHn) Hm: Values of 8 bits in PPG reload register (PRLLm) Lm: Values of 8 bits in PPG reload register (PRLHm) : Count clock cycle Note: n = C, E m = n + 1

309

# 16.6 Precautions when Using 8-/16-bit PPG Timer

This section explains the precautions when using the 8-/16-bit PPG timer.

# ■ Precautions when Using 8-/16-bit PPG Timer

- Effect on 8-/16-bit PPG timer when using timebase timer output
  - If the output signal of the timebase timer is used as the input signal for the count clock of the 8-/16-bit PPG timer (PPGnm: PCM2 to PCM0="111<sub>B</sub>", PCS2 to PCS0="111<sub>B</sub>"), deviation may occur in the first count cycle in which the PPG timer is started by trigger input or in the count cycle immediately after the PPG timer is stopped.
  - When the timebase timer counter is cleared (TBTC: TBR=0) during the count operation of the PPG down counter, deviation may occur in the count cycle.
- Setting of PPG reload registers when using 8-bit PPG timer
  - The Low-level and High-level pulse widths are determined at the timing of reloading the values in the Low-level PPG reload registers (PRLLn, PRLLm) to the PPG down counter.
  - If the 8-bit PPG timer is used in the 8-bit PPG output 2-channel independent operation mode or the 8 + 8-bit PPG output operation mode, use a word instruction to set both High-level and Low-level PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) at the same time.

Using a byte instruction may cause an unexpected pulse to be generated.

# [Example of rewriting PPG reload registers using byte instruction]

Immediately before the signal level of the PPG pin switches from High to Low, if the value in the High-level PPG reload register (PRLH) is rewritten after the value in the Low-level PPG reload register (PRLL) is rewritten using the byte instruction, a Low-level pulse width is generated after rewriting and a High-level pulse width is generated before rewriting.

Figure 16.6-1 shows the waveform as the values in the PPG reload registers are rewritten using the byte instruction.

Note: n = C, Em = n+1



Figure 16.6-1 Waveform when Values in PPG Reload Registers Rewritten Using Byte Instruction

### Setting of PPG reload registers when using 16-bit PPG timer

Use a long-word instruction to set the PPG reload registers (PRLLn/PRLHn, PRLLm/PRLHm) or a word instruction to set the word instruction to set the PPGn and PPGm (PRLLn --> PRLLn or PRLHm --> PRLHm) in this order.

# [Reload timing in 16-bit PPG output operation mode]

In the 16-bit PPG output operation mode, the reload values written to the PPGn reload registers (PRLLn, PRLHn) are written temporarily to the temporary latch, written to the PPGm reload registers (PRLLm/PRLHm), and then transferred to the PPGn reload registers (PRLLn/PRLHn). Therefore, when setting the reload value in the PPGm reload registers (PRLLm/PRLHm), it is necessary to set the reload value in the PPGn reload registers (PRLLn/PRLHn) simultaneously or set the reload value in the PPGn reload registers (PRLLn/PRLHn) before setting it in the PPGm reload registers (PRLLm/PRLHm).

Figure 16.6-2 shows the reload timing in the 16-bit PPG output operation mode.



Figure 16.6-2 Reload Timing in 16-bit PPG Output Operation Mode

# CHAPTER 17 DTP/EXTERNAL INTERRUPTS

This chapter explains the functions and operations of DTP/external interrupt.

- 17.1 Overview of DTP/External Interrupt
- 17.2 Block Diagram of DTP/External Interrupt
- 17.3 Configuration of DTP/External Interrupt
- 17.4 Explanation of Operation of DTP/External Interrupt
- 17.5 Precautions when Using DTP/External Interrupt
- 17.6 Program Example of DTP/External Interrupt Function

# 17.1 Overview of DTP/External Interrupt

The DTP/external interrupt sends interrupt requests from external peripheral devices or data transfer requests to the CPU to generate an external interrupt request, or starts the EI<sup>2</sup>OS.

# **■** DTP/External Interrupt Function

The DTP/external interrupt follows the same procedure as resource interrupts to send interrupt requests from external peripheral devices to the CPU to generate an external interrupt request, or starts the EI<sup>2</sup>OS.

If the EI<sup>2</sup>OS is disabled in the interrupt control register (ICR: ISE=0), the external interrupt function is enabled, branching to interrupt processing.

If the EI<sup>2</sup>OS is enabled, the DTP function is enabled and automatic data transfer is performed, branching to interrupt processing after the completion of data transfer for the specified number of times.

Table 17.1-1 shows an overview of the DTP/external interrupt.

Table 17.1-1 Overview of DTP/External Interrupt

|                      | External Interrupt                                                                                         | DTP Function                                                                                                                                                              |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Input pin            | 8 pins: INT8, INT9R, INT10, INT11, IN                                                                      | Γ12R, INT13, INT14R, INT15R                                                                                                                                               |  |  |
| Interrupt factor     | The interrupt factor is set in unit of pins us (ELVR1).                                                    | ing the detection level setting registers                                                                                                                                 |  |  |
| ппенирі настої       | Input of High level, Low level, rising edge, or falling edge  Input of High level or edge, or falling edge |                                                                                                                                                                           |  |  |
| Interrupt number     | #26(1A <sub>H</sub> ), #28(1C <sub>H</sub> )                                                               |                                                                                                                                                                           |  |  |
| Interrupt control    | The interrupt request output is enabled/disabled using the DTP/external interrupt enable register (ENIR1). |                                                                                                                                                                           |  |  |
| Interrupt flag       | The interrupt factor is held using the DTP/external interrupt factor register (EIRR1).                     |                                                                                                                                                                           |  |  |
| Processing selection | The EI <sup>2</sup> OS is disabled. (ICR: ISE=0)                                                           | The EI <sup>2</sup> OS is enabled. (ICR: ISE=1)                                                                                                                           |  |  |
| Processing contents  | A branch is caused to the external interrupt processing routine.                                           | EI <sup>2</sup> OS performs automatic data transfer<br>and completes the specified number of<br>time for data transfers, causing a branch<br>to the interrupt processing. |  |  |

# 17.2 Block Diagram of DTP/External Interrupt

The block diagram of the DTP/external interrupt is shown below.

# ■ Block Diagram of DTP/External Interrupt

Figure 17.2-1 Block Diagram of DTP/External Interrupt



# DTP/external interrupt input detection circuit

This circuit detects interrupt requests or data transfer requests generated from external peripheral devices.

The interrupt request flag bit corresponding to the pin whose level or edge set by the detection level setting register (ELVR) is detected is set to "1" (EIRR1:ER).

# Detection level setting register (ELVR1)

This register sets the level or edge of input signals from external peripheral devices that cause DTP/external interrupt factors.

# DTP/external interrupt factor register (EIRR1)

This register holds DTP/external interrupt factors.

If an enable signal is inputted to the DTP/external interrupt pin, the corresponding DTP/external interrupt request flag bit is set to "1".

# DTP/external interrupt enable register (ENIR1)

This register enables or disables DTP/external interrupt requests from external peripheral devices.

# ■ Details of Pins and Interrupt Numbers

Table 17.2-1 shows the pins and interrupt numbers used in the DTP/external interrupt.

Table 17.2-1 Pins and Interrupt Numbers Used by DTP/External Interrupt

| Pin | Channel | Interrupt number      |
|-----|---------|-----------------------|
| P54 | INT8    |                       |
| P42 | INT9R   | #26(1A <sub>H</sub> ) |
| P55 | INT10   | #20(1A <sub>H</sub> ) |
| P56 | INT11   |                       |
| P80 | INT12R  |                       |
| P57 | INT13   | #28(1C <sub>H</sub> ) |
| P82 | INT14R  | π20(1СΗ)              |
| P84 | INT15R  |                       |

INT9R, INT12R, INT14R, and INT15R are enabled by setting the corresponding bit of the external interrupt factor select register (EISSR) to "1".

# 17.3 Configuration of DTP/External Interrupt

This section lists and details the pins, interrupt factors, and registers in the DTP/ external interrupt.

# **■** Pins of DTP/External Interrupt

The pins used by the DTP/external interrupt serve as general-purpose I/O ports.

Table 17.3-1 lists the pin functions and the pin setting required for use in the DTP/external interrupt.

Table 17.3-1 Pins of DTP/External Interrupt

| Pin Name                         | Pin Function                                                                                                  | Pin Settings Required for Use in DTP/<br>External Interrupt                                                                                    |
|----------------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|
| P54/AN12/TOT3<br>/INT8           | General-purpose I/O ports, analog input, event pin for reload timer, DTP external interrupt inputs            | Set external interrupt factor select register  (EXCEP)                                                                                         |
| P55/AN13/INT10                   | 2                                                                                                             | <ul><li>(EISSR) to 0.</li><li>Set as input ports in port direction register</li></ul>                                                          |
| P56/AN14/INT11                   | General-purpose I/O ports, analog input, DTP external interrupt inputs                                        | (DDR5).                                                                                                                                        |
| P57/AN15/INT13                   |                                                                                                               |                                                                                                                                                |
| P42/<br>INT9R/<br>RX1/           | General-purpose I/O ports, DTP external interrupt inputs, CAN1 input Rx1                                      | <ul> <li>Set external interrupt factor select register (EISSR) to 1.</li> <li>Set as input ports in port direction register (DDR4).</li> </ul> |
| P80/<br>INT12R/<br>ADTG          | General-purpose I/O ports, DTP external interrupt inputs, A/D converter trigger input ADTG                    |                                                                                                                                                |
| P82/<br>INT14R/<br>SIN0/<br>TIN2 | General-purpose I/O ports, DTP external interrupt inputs, UART0 input SIN0, reload timer 2 trigger input TIN2 | <ul> <li>Set external interrupt factor select register (EISSR) to 1.</li> <li>Set as input ports in port direction register (DDR8).</li> </ul> |
| P84/<br>INT15R/<br>SCK0          | General-purpose I/O ports, DTP external interrupt inputs, UART0 clock I/O SCK0                                |                                                                                                                                                |

# ■ List of Registers and Reset Values in DTP/External Interrupt

Figure 17.3-1 List of Registers and Reset Values in DTP/External Interrupt

| ENID4                        |        |      |      |        |        |        |       |       | Reset value |
|------------------------------|--------|------|------|--------|--------|--------|-------|-------|-------------|
| ENIR1 bit ,                  | 7      | 6    | 5    | 4      | 3      | 2      | 1     | 0     |             |
| Address: 0000CA <sub>H</sub> | EN15   | EN14 | EN13 | EN12   | EN11   | EN10   | EN9   | EN8   | 00000000 B  |
|                              |        |      |      |        |        |        |       |       |             |
| EIRR1 bit                    | 15     | 14   | 13   | 12     | 11_    | 10     | 9     | 8     |             |
| Address: 0000CB <sub>H</sub> | ER15   | ER14 | ER13 | ER12   | ER11   | ER10   | ER9   | ER8   | XXXXXXXXB   |
|                              |        |      |      |        |        |        |       |       |             |
| ELVR1 bit                    | 7      | 6    | 5    | 4      | 3      | 2      | 1     | 0     |             |
| Address: 0000CC <sub>H</sub> | LB11   | LA11 | LB10 | LA10   | LB9    | LA9    | LB8   | LA8   | 00000000 B  |
|                              |        |      |      |        |        | ,      |       |       |             |
| ELVR1 bit                    | 15     | 14   | 13   | 12     | 11     | 10     | 9     | 8     |             |
| Address: 0000CD <sub>H</sub> | LB15   | LA15 | LB14 | LA14   | LB13   | LA13   | LB12  | LA12  | 00000000 B  |
| EISSR bit                    | 7      | 6    | 5    | 4      | 3      | 2      | 1     | 0     |             |
| Address: 0000CE H            | INT15R |      |      | INT12R | INT11R | INT10R | INT9R | INT8R | 00000000 B  |
|                              |        |      |      |        | 1      |        |       |       |             |
|                              |        |      |      |        |        |        |       |       |             |

# 17.3.1 DTP/External Interrupt Factor Register (EIRR1)

The DTP/external interrupt factor register holds DTP/external interrupt factors. When a valid signal is inputted to the DTP/external interrupt pin, the corresponding DTP/external interrupt request flag bit is set to "1".

The EIRR1 register is corresponding to INT8, INT9R, INT10, INT11, INT12R, INT13, INT14R, and INT15R.

# **■ DTP/External Interrupt Factor Register (EIRR1)**

Figure 17.3-2 DTP/External Interrupt Factor Register (EIRR1)



Table 17.3-2 Function of DTP/External Interrupt Factor Register (EIRR1)

| Bit Name            |                                                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------------|--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit8<br>to<br>bit15 | ER15 to ER8(EIRR1),<br>DTP/External interrupt<br>request flag bits | These bits are set to "1" when the edges or level signals set by the detection condition select bits in the detection level setting register (ELVR1:LB, LA) are inputted to the DTP/external interrupt pins.  When set to "1": When the DTP/external interrupt request enable bit (ENIR1:EN) is set to "1", an interrupt request is generated to the corresponding DTP/external interrupt channel.  When set to "0": Cleared  When set to "1": No effect  Note:  Reading by read-modify-write type instructions always returns "1".  If more than one DTP/external interrupt request is enabled (ENIR1:EN = 1), clear only the bit in the channel that accepts an interrupt (EIRR1:ER = 0). No other bits must be cleared unconditionally.  Reference:  When the EI <sup>2</sup> OS is started, the interrupt request flag bit is automatically cleared after the completion of data transfer (EIRR1:ER = 0). |

# 17.3.2 DTP/External Interrupt Enable Register (ENIR1)

The DTP/external interrupt enable register (ENIR1) enables/disables the DTP/external interrupt request in the external peripheral devices.

ENIR1 is corresponding to INT8, INT9R, INT10, INT11, INT12R, INT13, INT14R and INT15R.

# **■ DTP/External Interrupt Enable Register (ENIR1)**

Figure 17.3-3 DTP/External Interrupt Enable Register (ENIR1)



Table 17.3-3 Functions of DTP/External Interrupt Enable Register (ENIR1)

|                    | Bit Name                                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit0<br>to<br>bit7 | EN15 to EN8(ENIR1),<br>DTP/external interrupt<br>request enable bits | These bits enable or disable the DTP/external interrupt request to the DTP/external interrupt channel.  If the DTP/external interrupt request enable bit (ENIR1:EN) and the DTP/external interrupt request flag bit (EIRR1:ER) are set to "1", the interrupt request is generated to the corresponding DTP/external interrupt pin.  Reference:  The state of the DTP/external interrupt pin can be read directly using the port data register irrespective of the setting of the DTP/external interrupt request enable bit. |

Table 17.3-4 Correspondence between DTP/External Interrupt Pins, DTP/External Interrupt Request Flag Bits, and DTP/External Interrupt Request Enable Bits

| DTP/external interrupt pin | DTP/external interrupt request flag bit | DTP/external interrupt request enable bit |
|----------------------------|-----------------------------------------|-------------------------------------------|
| INT8                       | ER8                                     | EN8                                       |
| INT9R                      | ER9                                     | EN9                                       |
| INT10                      | ER10                                    | EN10                                      |
| INT11                      | ER11                                    | EN11                                      |
| INT12R                     | ER12                                    | EN12                                      |
| INT13                      | ER13                                    | EN13                                      |
| INT14R                     | ER14                                    | EN14                                      |
| INT15R                     | ER15                                    | EN15                                      |

# 17.3.3 Detection Level Setting Register (ELVR1)

The detection level setting register sets the level or edge of input signals that cause the interrupt factors of the DTP/external interrupt pin.

ELVR1 is corresponding to INT8, INT9R, INT10, INT11, INT12R, INT13, INT14R and INT15R.

# ■ Detection Level Setting Register (ELVR1)

15 14 13 12 11 10 9 Reset value Address |LB15|LA15|LB14|LA14|LB13|LA13|LB12|LA12|LB11|LA11|LB10|LA10| LB9 | LA9 | LB8 | LA8 | ELVR1:0000CCB 0000000000000000 bit15 to bit0 LB15,LA15,LB14,LA14, LB13,LA15,LB12,LA12, LB11,LA11,LB10,LA10, LB9 ,LA9 ,LB8 ,LA8 Detection condition select bit 0 Low level detection High level detection R/W: Read/Write 0 Rising edge detection : Reset value

Figure 17.3-4 Detection Level Setting Register (ELVR1)

Table 17.3-5 Functions of Detection Level Setting Register (ELVR1)

| Bit Name            |                                                               | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------|---------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit0 | ELVR1 LB15, LA15 to LB8, LA8  Detection condition select bits | These bits set the levels or edges of input signals from external peripheral devices that cause interrupt factors in the DTP/external interrupt pins.  • Two levels or two edges are selectable for external interrupts, and two levels are selectable for the EI <sup>2</sup> OS.  Reference:  When the set detection signal is input to the DTP/external interrupt pins, the DTP/external interrupt request flag bits are set to "1" even if DTP/external interrupt requests are disabled (ENIR1:EN = 0). |

1

1

Falling edge detection

Table 17.3-6 Correspondence between Detection Level Setting Register and Channels

| DTP/External Interrupt Pin | Register Name | Bit Name   |
|----------------------------|---------------|------------|
| INT8                       |               | LB8, LA8   |
| INT9R                      |               | LB9, LA9   |
| INT10                      |               | LB10, LA10 |
| INT11                      | ELVR1         | LB11, LA11 |
| INT12R                     |               | LB12, LA12 |
| INT13                      |               | LB13, LA13 |
| INT14R                     |               | LB14, LA14 |
| INT15R                     |               | LB15, LA15 |

# 17.3.4 External Interrupt Factor Select Register (EISSR)

The external interrupt factor select register (EISSR) can change the assignment of the external interrupt pin. This allows the external interrupt. Also, the function such as CAN wakeup is implemented.

# ■ Selection of External Interrupt Factor

The external interrupt pin of the upper 8-bit is assigned to INT13, INT11, INT10, and INT8 normally and shares the port 5 and pin. In the external bus mode, the port 0 cannot be used as the external interrupt pin. The pin is switched by the external interrupt factor select register (EISSR). In addition, because INT15R, INT14R, INT12R, and INT9R share the function such as CAN input pin, the function such as CAN wakeup can be implemented.

See Table 17.3-8 for the pin function of INT15R, INT14R, INT12R, and INT9R.

Address EISSR: 0000CEH INT15R INT14R INT13R INT12R INT11R INT10R INT9R INT8R Reset value 0000000B R/W R/W R/W R/W R/W R/W R/W bit7 to bit0 INT15R to INT8R External interrupt factor select bit R/W: Read/Write Set pins INT15 to INT8 as external interrupt factor : Undefined Set pins INT15R to INT8R as external interrupt factor 1 : Reset value See Table 17.3-8 "External interrupt factor select (upper 8-bit)" for the pin assignment of INT15R to INT8R.

Figure 17.3-5 DTP/external Interrupt Factor Select Register (EISSR)

Table 17.3-7 Function of DTP/external Interrupt Factor Select Register (EISSR)

|                    | Bit Name                                                     | Function                                                                                                                                                                                                                                                                                                                                                         |
|--------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7<br>to<br>bit0 | INT15R to INT8R:<br>External interrupt factor<br>select bits | When these bits are set to "1", the input pin of the corresponding external interrupt factor (upper 8-bit) is assigned to the INT15R to INT8R.  When set to "0": The external interrupt factor of the upper 8-bit is assigned to INT15 to INT8 pins.  When set to "1": The external interrupt factor of the upper 8-bit is assigned to the INT15R to INT8R pins. |

Table 17.3-8 External Interrupt Factor Select (Upper 8-bit)

| EISSR Bit | "0" (Initial Value)   | "1"                     |
|-----------|-----------------------|-------------------------|
| INT8R     | INT8: P54 (AN12/TOT3) | -                       |
| INT9R     | -                     | INT9R: P42 (RX1)        |
| INT10R    | INT10: P55 (AN13)     | -                       |
| INT11R    | INT11: P56 (AN14)     | -                       |
| INT12R    | -                     | INT12R: P80 (ADTG)      |
| INT13R    | INT13: P57 (AN15)     | -                       |
| INT14R    | -                     | INT14R: P82 (SIN0/TIN2) |
| INT15R    | -                     | INT15R: P84 (SCK0)      |

# 17.4 Explanation of Operation of DTP/External Interrupt

The DTP/external interrupt has an external interrupt function and a DTP function. The setting and operation of each function are explained.

# ■ Setting of DTP/External Interrupt

Using the DTP/external interrupt requires, the setting shown in Figure 17.4-1.

Figure 17.4-1 Setting of DTP/External Interrupt



# Setting procedure

To use the DTP/external interrupt, set each register by using the following procedure:

- 1. Set the input port to the general-purpose I/O port, which is shared with the terminal to be used as external interrupt input.
- 2. Set the external interrupt factor select register (EISSR) corresponding to the DTP/external interrupt channel to be used.
- 3. Set the interrupt request enable bit corresponding to the DTP/external interrupt channel to be used to 0 (ENIR1:EN).
- 4. Use the detection condition select bit corresponding to the DTP/external interrupt pin to be used to set the edge or level to be detected (ELVR1: LA, LB).
- 5. Set the interrupt request flag bit corresponding to the DTP/external interrupt channel to be used to 0 (EIRR1: ER).
- 6. Set the interrupt request enable bit corresponding to the DTP/external interrupt channel to be used to 1 (ENIR1: EN).

Note that concurrent writing with 16-bit data is available in 5 and 6.

- When setting the registers for the DTP/external interrupt, the external interrupt request must be disabled in advance (ENIR1: EN = 0).
- When enabling the DTP/external interrupt request (ENIR1:EN = 1), the corresponding DTP/external interrupt request flag bit must be cleared in advance (EIRR1:ER = 0). These actions prevent the mistaken interrupt request from occurring when setting the register.

### Selecting of DTP or external interrupt function

Whether the DTP function or the external interrupt function is executed depends on the setting of the EI<sup>2</sup>OS enable bit in the corresponding interrupt control register (ICR:ISE).

If the ISE bit is set to "1", the EI<sup>2</sup>OS is enabled.

If the ISE bit is set to "0", the EI<sup>2</sup>OS is disabled and the external interrupt function is executed.

### **Notes:**

- All interrupt requests assigned to one interrupt control register have the same interrupt levels (IL2 to IL0).
- If two or more interrupt requests are assigned to one interrupt control register and the EI<sup>2</sup>OS is used in one of them, other interrupt requests cannot be used.
- Enabling unequipped terminals causes a false operation. First set the EISSR and then set each of the registers when DTP/external interrupt is used.

# **■** DTP/External Interrupt Operation

The control bits and the interrupt factors for the DTP/external interrupt are shown in Table 17.4-1 .

Table 17.4-1 Control Bits and Interrupt Factors for DTP/External Interrupt

|                              | DTP/External interrupt                                                                        |  |
|------------------------------|-----------------------------------------------------------------------------------------------|--|
| Interrupt request flag bit   | EIRR1: ER15 to ER8                                                                            |  |
| Interrupt request enable bit | ENIR1: EN15 to EN8                                                                            |  |
| Interrupt factor             | Input of valid edge or level to INT13, INT11, INT10, INT8, INT9R, INT12R, INT14R, INT15R pins |  |

If the interrupt request signal from the DTP/external interrupt is output to the interrupt controller and the  $EI^2OS$  enable bit in the interrupt control register (ICR:ISE) is set to "0", the interrupt processing is executed. This bit is set to "1", the  $EI^2OS$  is executed.

Figure 17.4-2 shows the operation of the DTP/external interrupt.



Figure 17.4-2 Operation of DTP/External Interrupt

# 17.4.1 External Interrupt Function

The DTP/external interrupt has an external interrupt function for generating an interrupt request by detecting the signal (edge or level) in the DTP/external interrupt pin.

# **■** External Interrupt Function

- When the signal (edge or level) set in the detection level setting register is detected in the DTP/external interrupt pin, the interrupt request flag bit in the DTP/external interrupt factor register (EIRR1:ER) is set to "1".
- If the interrupt request enable bit in the DTP/external interrupt enable register is enabled (ENIR1:EN = 1) with the interrupt request flag bit set to "1", the interrupt request generation is posted to the interrupt controller.
- If an interrupt request is preferred to other interrupt request by the interrupt controller, the interrupt request is generated.
- If the level of an interrupt request (ICR:IL) is higher than that of the interrupt level mask bit in the condition code register (CCR:ILM) and the interrupt enable bit is enabled (PS:CCR:I = 1), the CPU performs interrupt processing after completion of the current instruction execution and branches to interrupt processing.
- At interrupt processing, set the corresponding DTP/external interrupt request flag bit to 0 and clear the DTP/external interrupt request.

### **Notes:**

- When the DTP/external interrupt start factor is generated, the DTP/external interrupt request flag bit (EIRR1:ER) is set to "1", regardless of the setting of the DTP/external interrupt request enable bit (ENIR1:EN).
- When the interrupt processing is started, clear the DTP/external interrupt request flag bit that caused the start factor. Control cannot be returned from the interrupt while the DTP/external interrupt request flag bit is set to "1". When clearing, do not clear any flag bit other than the accepted DTP/external interrupt factor.

# 17.4.2 DTP Function

The DTP/external interrupt has the DTP function that detects the signal of the external peripheral device from the DTP/external interrupt pin to start the El<sup>2</sup>OS.

### **■** DTP Function

The DTP function detects the signal level set by the detection level setting register of the DTP/external interrupt function to start the  $EI^2OS$ .

- When the EI<sup>2</sup>OS operation is already enabled (ICR:ISE = 1) at the point when the interrupt request is accepted by the CPU, the DTP function starts the EI<sup>2</sup>OS and starts data transfer.
- When transfer of one data item is completed, the descriptor is updated and the DTP/external interrupt request flag bit is cleared to prepare for the next request from the DTP/external interrupt pin.
- When the EI<sup>2</sup>OS completes transfer of all the data, control branches to the interrupt processing.

Figure 17.4-3 Example of Interface with External Peripheral Device (when using El<sup>2</sup>OS in Single-chip mode)



# 17.5 Precautions when Using DTP/External Interrupt

This section explains the precautions when using the DTP/external interrupt.

# ■ Precautions when Using DTP/External Interrupt

- Condition of external-connected peripheral device when DTP function is used
  - When using the DTP function, the peripheral device must automatically clear a data transfer request when data transfer is performed.
  - Inactivate the transfer request signal within three machine clocks after starting data transfer. If the transfer request signal remains active, the DTP/external interrupt regards the transfer request signal as a generation of next transfer request.

# External interrupt input polarity

- When the edge detection is set in the detection level setting register, the pulse width for edge detection must be at least three machine clocks.
- When a level causing an interrupt factor is inputted with level detection set in the detection level setting register, factor F/F in the DTP/external interrupt factor register is set to "1" and the factor is held as shown in Figure 17.5-1.

With the factor held in factor F/F, the request to the interrupt controller remains active if the interrupt request is enabled (ENIR1: EN = 1) even after the DTP/external interrupt factor is cancelled. To cancel the request to the interrupt controller, clear the external interrupt request flag bit (EIRR1: ER) and clear the factor F/F as shown in Figure 17.5-2.

Figure 17.5-1 Clearing Factor Hold Circuit when Level Set



Figure 17.5-2 DTP/External Interrupt Factor and Interrupt Request Generated when Interrupt Request Enabled



# CHAPTER 17 DTP/EXTERNAL INTERRUPTS

# Precautions on interrupts

- When the DTP/external interrupt is used as the external interrupt function, no return from interrupt processing can be made with the DTP/external interrupt request flag bit set to "1" (EIRR1:ER) and the DTP/external interrupt request set to "enabled" (ENIR1:EN = 1). Always set the DTP/external interrupt request flag bit to 0 (EIRR1:ER) at interrupt processing.
- When the level detection is set in the detection level setting register and the level that becomes the interrupt factor remains input, the DTP/external interrupt request flag bit is reset immediately even when cleared (EIRR1:ER = 0). Disable the DTP/external interrupt request output as needed (ENIR1:EN = 0), or cancel the interrupt factor itself.

# 17.6 Program Example of DTP/External Interrupt Function

This section gives a program example of the DTP/external interrupt function.

# ■ Program Example of DTP/External Interrupt Function

# Processing specifications

An external interrupt is generated by detecting the rising edge of the pulse input to the INT8 pin.

# Coding example

```
ICR07 EQU
            0000B7H
                               ;Interrupt control register ICR7
                               ; Port 5 direction register
DDR5
       EQU
            000015H
            0000CAH
                               ;DTP/external interrupt enable
ENIR1 EOU
                                register 1
                                ;DTP/external interrupt factor
EIRR1 EOU
            0000CBH
                                register 1
ELVR1L EQU
           0000CCH
                                ;Detection level setting register 1: "L"
                                ;Detection level setting register 1: "H"
ELVR1H EQU
            0000CDH
ADER5 EQU
           00000BH
                               ;Port5 analog input enable register
ER8
      EQU
            EIRR1:0
                                ; INT8 Interrupt request flag bit
      EQU
                               ; INT8 Interrupt request enable bit
EN8
            ENIR1:0
;------Main program-----
CODE
       CSEG
                      ;Stack pointer (SP) already initialized
START:
            I:ADER5, #00000000B; Set analog input of Port5 to disable
      VOM
      MOV
            I:DDR5, #00000000B ; Set DDR5 to input port
            CCR, #0BFH
                               ;Interrupts disabled
      AND
            I:ICR07,#00H
                              ;Interrupt level 0 (highest)
      VOM
       CLRB I:EN8
                               ; INT8 disabled using ENIR1
      VOM
            I:ELVROL, #00000010B; Rising edge selected for INT8
                               ;INT8 interrupt flag cleared using
       CLRB I:ER0
                                ;EIRR1
      SETB I:EN8
                               ; INT8 interrupt request enabled using
                                ENIR1
                               ;Set ILM in PS to level 7
       VOM
             ILM, #07H
            CCR, #40H
                               ; Interrupts enabled
       OR
LOOP:
       ÅE
       Processing by user
       ÅE
       BRA
            LOOP
;-----Interrupt program-----
WARI:
       CLRB
             I:ER8
                                ;Interrupt request flag cleared
```

```
ÅE
       Processing by user
      ÅE
      RETI
                            ;Return from interrupt processing
CODE
      ENDS
;------Vector setting------
      CSEG ABS=0FFH
VECT
      ORG
          00FF94H
                           ;Set vector to interrupt number
                            #26(1A<sub>H</sub>)
      DSL
           WARI
      ORG 00FFDCH
                           ;Reset vector set
      DSL
           START
           00H
                            ;Set to single-chip mode
      DB
VECT
      ENDS
      END
           START
```

# **■** Program Example of DTP Function

- Processing specification
  - Channel 0 of the EI<sup>2</sup>OS is started by detecting the High level of the signal input to the INT8 pin.
  - RAM data is outputted to port 5 by performing DTP processing (EI<sup>2</sup>OS).

# Coding example

| ICR07  | EQU | 0000B7H | ;DTP/external interrupt control register  |  |
|--------|-----|---------|-------------------------------------------|--|
| DDR6   | EQU | 000016H | ;Port 6 direction register                |  |
| DDR5   | EQU | 000015H | ;Port 5 direction register                |  |
| ENIR1  | EQU | 0000CAH | ;DTP/external interrupt enable register 1 |  |
| EIRR1  | EQU | 0000CBH | ;DTP/external interrupt factor register 1 |  |
| ELVR1L | EQU | 0000CCH | ;Detection level setting register 1:"L"   |  |
| ELVR1H | EQU | 0000CDH | ;Detection level setting register 1:"H"   |  |
| ADER5  | EQU | 00000BH | ;Port5 analog input enable register       |  |
| ADER6  | EQU | 00000CH | ;Port6 analog input enable register       |  |
| ER1    | EQU | EIRR:0  | ;INT8 interrupt request flag bit          |  |
| EN1    | EQU | ENIR:0  | ;INT8 interrupt request enable bit        |  |
| ;      |     |         |                                           |  |
| BAPL   | EQU | 000100H | ;Buffer address pointer lower             |  |
| BAPM   | EQU | 000101H | ;Buffer address pointer middle            |  |
| BAPH   | EQU | 000102H | ;Buffer address pointer higher            |  |
| ISCS   | EQU | 000103H | ;EI <sup>2</sup> OS status register       |  |
| IOAL   | EQU | 000104H | ;I/O address register lower               |  |
| IOAH   | EQU | 000105H | ;I/O address register higher              |  |
| DCTL   | EQU | 000106H | ;Data counter lower                       |  |
| DCTH   | EQU | 000107H | ;Data counter higher                      |  |

```
;-----Main program------
CODE
      CSEG
START:
                      ;Stack pointer (SP) already initialized
      VOM
            I:ADER5, #00000000B ; Set analog input of port5 to disable
            I:ADER6, #00000000B; Set analog input of port6 to disable
      MOV
      VOM
            I:DDR6, #11111111B ;Set DDR6 to output port
      VOM
            I:DDR5, #00000000B ; Set DDR5 to input port
            CCR, #0BFH
                             ;Interrupts disabled
      AND
           I:ICR07,#08H
                              ;Interrupt level 0 (highest) EI2OS
      VOM
                              ;Channel 0
;Data bank register (DTB) = 00H
                              ; Address for storing output data set
      MOV
            BAPL, #00H
      VOM
           BAPM, #06H
                              ; (600_{\rm H} to 60A_{\rm H} used)
      VOM
           BAPH, #00H
                              ;Byte transfer, buffer address +1,
      VOM
            ISCS, #12H
                              ;I/O address fixed,
                              ;transfer from memory to I/O
                              ;Set port 0 as transfer destination
      MOV
            IOAL,#00H
      VOM
            IOAH, #00H
                             ;address pointer
                              ;Set transfer count to 10
      VOM
            DCTL, #0AH
      VOM
            DCTH, #00H
;
      CLRB
           I:EN8
                              ; INT8 disabled using ENIR1
            I:ELVR1L, #00000001B; H level detection set for INT8
      MOV
      CLRB I:ER8
                              ;INT8 interrupt request flag cleared
                              ;using EIRR1
      SETB I:EN8
                              ;INT8 interrupt request enabled using
                               ENIR1
      VOM
            ILM,#07H
                              ;Set ILM in PS to level 7
      OR
            CCR, #40H
                             ;Interrupts enabled
LOOP:
      ÅE
      Processing by user
      ÅE
      BRA
           LOOP
;-----Interrupt program-----
WARI:
      CLRB
             I:ER8
                               ;INT8 interrupt request flag cleared
      ÅE
      Processing by user
      ÅE
       RETI
                              ; Return from interrupt processing
CODE
      ENDS
;-----Vector setting------
      CSEG ABS=0FFH
VECT
      ORG
           00FF94H
                             ;Set vector to interrupt number
```

# CHAPTER 17 DTP/EXTERNAL INTERRUPTS

END

START

# **CHAPTER 18**

# 8-/10-BIT A/D CONVERTER

This chapter explains the functions and operation of 8-/ 10-bit A/D converter.

- 18.1 Overview of 8-/10-bit A/D Converter
- 18.2 Block Diagram of 8-/10-bit A/D Converter
- 18.3 Configuration of 8-/10-bit A/D Converter
- 18.4 Interrupt of 8-/10-bit A/D Converter
- 18.5 Explanation of Operation of 8-/10-bit A/D Converter
- 18.6 Precautions when Using 8-/10-bit A/D Converter

# 18.1 Overview of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter converts the analog input voltage to a 8- or 10-bit digital value by using the RC sequential-comparison converter system.

- An input signal can be selected from the input signals of the analog input pins for 16 channels.
- The start trigger can be selected from a software trigger and an external trigger.

### ■ Function of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter converts the analog voltage (input voltage) input to the analog input pin into an 8- or 10-bit digital value (A/D conversion).

The 8-/10-bit A/D converter has the following functions:

- A/D conversion time is a minimum of 1.9 μs\* per channel including sampling time.
- Sampling time is a minimum of 0.5 µs\* per channel.
- RC sequential-comparison converter system with sample & hold circuit
- Setting of 8-bit or 10-bit resolution enabled
- Analog input pin can be used up to 16 channels.
- Generates interrupt request by storing A/D conversion results in A/D data register
- Starts EI<sup>2</sup>OS if interrupt request generated. Use of the EI<sup>2</sup>OS prevents data loss even at continuous A/D conversion.
- Selects start trigger from software trigger and external trigger (falling edge)
- \*: When the machine clock frequency operates at 24 MHz and  $AV_{CC} \ge 4.5 \text{ V}$ .

# ■ Conversion Modes of 8-/10-bit A/D Converter

There are 3 conversion modes of 8-/10-bit A/D converter as shown below:

Table 18.1-1 Conversion Modes of 8-/10-bit A/D Converter

| Conversion<br>Mode          | Description                                                                                                                                                                                      |  |
|-----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Single-shot conversion mode | A/D conversion is performed sequentially from the start channel to the end channel. When A/D conversion for the end channel is terminated, it stops.                                             |  |
| Continuous conversion mode  | A/D conversion is performed sequentially from the start channel to the end channel. When A/D conversion for the end channel is terminated, it is continued after returning to the start channel. |  |
| Pause-conversion mode       | A/D conversion is performed pausing per channel. When A/D conversion for the end channel is terminated, A/D conversion and pause are repeated after returning to the start channel.              |  |

# 18.2 Block Diagram of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter consists of following blocks.

# ■ Block Diagram of 8-/10-bit A/D Converter

Figure 18.2-1 Block Diagram of 8-/10-bit A/D Converter



# Details of pins in block diagram

Table 18.2-1 shows the actual pin names and interrupt request numbers of the 8-/10-bit A/D converter.

Table 18.2-1 Pins and Interrupt Request Numbers in Block Diagram

| Pin Name/Inte            | rrupt Request Number in Block<br>Diagram | Actual Pin Name/Interrupt Request<br>Number                                                                      |  |
|--------------------------|------------------------------------------|------------------------------------------------------------------------------------------------------------------|--|
| ADTG                     | Trigger input pin                        | P80/ADTG/INT12R                                                                                                  |  |
| AN0 to AN7               | Analog input pin ch0 to ch7              | P60/AN0 to P65/AN5<br>P66/AN6/PPGC(D)<br>P67/AN7/PPGE(F)                                                         |  |
| AN8 to AN15              | Analog input pin ch8 to ch15             | P50/AN8 to P52/AN10<br>P53/AN11/TIN3<br>P54/AN12/TOT3/INT8<br>P55/AN13/INT10<br>P56/AN14/INT11<br>P57/AN15/INT13 |  |
| AVR                      | Vref+ input pin                          | AVR                                                                                                              |  |
| AV <sub>CC</sub>         | V <sub>CC</sub> input pin                | AV <sub>CC</sub>                                                                                                 |  |
| AV <sub>SS</sub>         | V <sub>SS</sub> input pin                | AV <sub>SS</sub>                                                                                                 |  |
| Interrupt request output | Interrupt request output                 | #29(1D <sub>H</sub> )                                                                                            |  |

# A/D control status registers (ADCS)

This register starts the A/D conversion function by software, selects the start trigger for the A/D conversion function, selects the conversion mode, enables or disables an interrupt request, checks and clears the interrupt request flag, temporarily stops A/D conversion and checks the state during conversion, and sets the resolution.

# A/D data registers (ADCR)

This register stores the A/D conversion results.

### A/D setting register (ADSR)

Starting channel and end channel of A/D conversion, compare time of A/D conversion and sampling time are set.

# Start selector

This selector selects the trigger to start A/D conversion. An external pin input can be set as the start trigger.

### Decoder

This decoder sets the A/D conversion start channel select bits and the A/D conversion end channel select bits in the A/D control status register (ADSR0:ANS3 to ANS0 and ANE3 to ANE0) to select the analog input pin to be used for A/D conversion.

# Analog channel selector

This selector selects the pin to be used for A/D conversion from the 16-channel analog input pins by receiving a signal from the decoder.

# Sample & hold circuit

This circuit holds the input voltage selected by the analog channel selector. By holding the input voltage immediately after A/D conversion is started, A/D conversion is performed without being affected by the fluctuation of the input voltage during A/D conversion.

### D/A converter

This converter generates the reference voltage which is compared with the input voltage held in the sample & hold circuit.

# Comparator

This comparator compares the D/A converter output voltage with input voltage held in the sample & hold circuit to determine the amount of voltage.

### Controller

This circuit determines the A/D conversion value by receiving the signal indicating the amount of voltage determined by the comparator. When the A/D conversion results are determined, the result data is stored in the A/D data register. If an interrupt request is enabled, an interrupt is generated.

# 18.3 Configuration of 8-/10-bit A/D Converter

This section explains the pins, registers, and interrupt factors of the A/D converter.

# ■ Pins of 8-/10-bit A/D Converter

The pins of the 8-/10-bit A/D converter serve as general-purpose I/O ports. Table 18.3-1 shows the pin functions and the setting required for use of the 8-/10-bit A/D converter.

Table 18.3-1 Pins of 8-/10-bit A/D Converter

| Function<br>Name | Pin Name                 | Pin Function                                                                                               | Setting Required for Use of 8-/10-bit<br>A/D Converter                                   |
|------------------|--------------------------|------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|
| Trigger input    | P80 / ADTG/INT12R        | General-purpose I/O port,<br>external trigger input,<br>external interrupt                                 | Set as input port in port direction register (DDR8).                                     |
| Channel 0        | P60 / AN0                |                                                                                                            | Enable input of analog signal (ADER6: set the corresponding bit of ADE7 to ADE0 to "1")  |
| Channel 1        | P61 / AN1                |                                                                                                            |                                                                                          |
| Channel 2        | P62 / AN2                | General-purpose I/O ports,                                                                                 |                                                                                          |
| Channel 3        | P63 / AN3                | analog inputs                                                                                              |                                                                                          |
| Channel 4        | P64 / AN4                |                                                                                                            |                                                                                          |
| Channel 5        | P65 / AN5                |                                                                                                            |                                                                                          |
| Channel 6        | P66 / AN6/PPGC(D)        | General-purpose I/O ports, analog inputs, PPG output  General-purpose I/O ports, analog inputs, PPG output |                                                                                          |
| Channel 7        | P67 / AN7/PPGE(F)        |                                                                                                            |                                                                                          |
| Channel 8        | P50 / AN8                |                                                                                                            | Enable input of analog signal (ADER5: set the corresponding bit of ADE15 to ADE8 to "1") |
| Channel 9        | P51 / AN9                | General-purpose I/O ports, analog inputs                                                                   |                                                                                          |
| Channel 10       | P52 / AN10               |                                                                                                            |                                                                                          |
| Channel 11       | P53 / AN11/TIN3          | General-purpose I/O ports,<br>analog inputs,<br>event input pin for reload timer                           |                                                                                          |
| Channel 12       | P54 / AN12/TOT3/<br>INT8 | General-purpose I/O ports,<br>analog inputs,<br>external interrupt input,<br>output pin for reload timer   |                                                                                          |
| Channel 13       | P55 / AN13/INT10         | General-purpose I/O ports,                                                                                 |                                                                                          |
| Channel 14       | P56 / AN14/INT11         | analog inputs,                                                                                             |                                                                                          |
| Channel 15       | P57 / AN15/INT13         | external interrupt input                                                                                   |                                                                                          |

#### ■ List of Registers and Reset Values of 8-/10-bit A/D Converter

Figure 18.3-1 List of Register and Reset Value of 8-/10-bit A/D Converter



#### ■ Generation of Interrupt from 8-/10-bit A/D Converter

In the 8-/10-bit A/D converter, when the A/D conversion results are stored in the A/D data register (ADCR0, 1), the interrupt request flag bit in the A/D control status register (ADCS1:INT) is set to "1". When an interrupt request is enabled (ADCS1:INTE = 1), an interrupt is generated.

# 18.3.1 A/D Control Status Register (High) (ADCS1)

The A/D control status register (High) (ADCS1) provides the following settings:

- Starting A/D conversion function by software
- Selecting start trigger for A/D conversion
- Storing A/D conversion results in A/D data register to enable or disable interrupt request
- Storing A/D conversion results in A/D data register to check and clear interrupt request flag
- Pausing A/D conversion and checking state during conversion

#### A/D Control Status Register (High) (ADCS1)

Figure 18.3-2 A/D Control Status Register (High) (ADCS1)



Table 18.3-2 Function of Each Bit of A/D Control Status Register (High) (ADCS1) (1/2)

| Bit name |                                          | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
|----------|------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit15    | BUSY:<br>A/D conversion-on<br>flag bit   | This bit forcibly terminates the 8-/10-bit A/D converter. When read, this bit indicates whether the 8-/10-bit A/D converter is operating or stopped.  When set to "0": Forcibly terminates 8-/10-bit A/D converter  When set to "1": No effect  Read: 1 is read when the 8-/10-bit A/D converter is operating and 0 is read when the converter is stopped.  Note:  • "1" is read from this bit when an read-modify-write instruction is used.  • In the single-shot mode, this bit is cleared when A/D conversion ends.  • In the continuous or pause mode, the A/D conversion does not stop until writing "0" to this bit.  • Do not perform the forced stop (BUSY=0) and the activation of the A/D converter concurrently (using software (STRT=1), external trigger, or timer). |  |
| bit14    | INT:<br>Interrupt request flag<br>bit    | <ul> <li>This bit indicates that an interrupt request is generated.</li> <li>When A/D conversion is terminated and its results are stored in the A/D data register (ADCR0, 1), the INT bit is set to "1".</li> <li>When the interrupt request flag bit is set (INT = 1) with an interrupt request enabled (INTE = 1), an interrupt request is generated.</li> <li>When set to "0": Cleared</li> <li>When set to "1": No effect</li> <li>When EI<sup>2</sup>OS function started: Cleared</li> <li>Note: <ul> <li>"1" is read from this bit when an read-modify-write instruction is used.</li> <li>To clear the INT bit, write 0 when the 8-/10-bit A/D converter is stopped.</li> </ul> </li> </ul>                                                                                |  |
| bit13    | INTE:<br>Interrupt request<br>enable bit | This bit enables or disables output of an interrupt request.  • When the interrupt request flag bit is set (INT =1) with an interrupt request enabled (INTE = 1), an interrupt request is generated.  Note:  Always set this bit to 1 when the EI <sup>2</sup> OS function is used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |

Table 18.3-2 Function of Each Bit of A/D Control Status Register (High) (ADCS1) (2/2)

|                 | Bit name                                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
|-----------------|------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit12           | PAUS:<br>Pause flag bit                                    | <ul> <li>This bit indicates the A/D conversion operating state when the EI<sup>2</sup>OS function is used.</li> <li>The PAUS bit is enabled only when the EI<sup>2</sup>OS function is used.</li> <li>When next A/D conversion terminates before the A/D conversion result completes the transfer from the A/D data register (ADCR0, 1) to memory, the A/D conversion pauses in order to prevent previous data from being overwritten. When the A/D conversion pauses, the PAUS bit is set to "1".</li> <li>After transfer of the A/D conversion results to memory, the 8-/10-bit A/D converter automatically resumes A/D conversion.</li> <li>Note:</li> <li>See "18.5.5 A/D-converted Data Protection Function" for the conversion data protection function.</li> <li>This bit is not cleared even if the pause state is cancelled. To clear this bit, write "0" to it.</li> </ul> |  |
| bit11,<br>bit10 | STS1, STS0:<br>A/D conversion start<br>trigger select bits | These bits select the trigger to start the 8-/10-bit A/D converter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |
| bit9            | STRT:<br>A/D conversion<br>software start bit              | <ul> <li>This bits starts the 8-/10-bit A/D converter by software.</li> <li>When set to "1": Starts 8-/10-bit A/D converter</li> <li>If A/D conversion pauses in the pause-conversion mode, it is resumed by writing 1 to the STRT bit.</li> <li>When set to "0": Invalid. The state remains unchanged.</li> <li>Note:</li> <li>The read-modify-write instructions read "0".</li> <li>The byte/word command reads "1".</li> <li>Do not perform forcible termination (BUSY = 0) and software start (STRT = 1) of the 8-/10-bit A/D converter simultaneously.</li> </ul>                                                                                                                                                                                                                                                                                                               |  |
| bit8            | Undefined bit                                              | <ul><li>Read: "1" is always read.</li><li>Write: No effect</li></ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |

# 18.3.2 A/D Control Status Register (Low) (ADCS0)

The A/D control status register (Low) (ADCS0) provides the following settings:

- Selecting A/D conversion mode
- Selecting start channel and end channel of A/D conversion
- A/D Control Status Register (Low) (ADCS0)

Figure 18.3-3 A/D Control Status Register (Low) (ADCS0)



Table 18.3-3 Function of Each Bit of A/D Control Status Register (Low) (ADCS0)

|              | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|--------------|-------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit7<br>bit6 | MD1, MD0:<br>A/D conversion<br>mode select bits | These bits set the A/D conversion mode 1:  The analog inputs from the start channel (ADSR0 : ANS3 to ANS0) to the end channel (ADSR0 : ANE3 to ANE0) are A/D-converted continuously.  The A/D conversion pauses after A/D conversion for the end channel.  This mode can be restarted during A/D conversion.  Single-shot conversion mode 2:  The analog inputs from the start channel (ADSR0 : ANS3 to ANS0) to the end channel (ADSR0 : ANE3 to ANE0) are A/D-converted continuously.  The A/D conversion pauses after A/D conversion for the end channel.  This mode cannot be restarted during A/D conversion.  Continuous conversion mode:  The analog inputs from the start channel (ADSR0 : ANS3 to ANS0) to the end channel (ADSR0 : ANE3 to ANE0) are A/D-converted continuously.  The analog inputs from the start channel (ADSR0 : ANS3 to ANS0) to the end channel (ADSR0 : ANE3 to ANE0) are A/D-converted continuously.  When A/D conversion for the end channel is terminated, it is continued after returning to the analog input for the start channel.  To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS1:BUSY).  This mode cannot be restarted during A/D conversion.  Pause conversion mode:  A/D conversion for the start channel (ADSR0 : ANS3 to ANS0) starts. The A/D conversion pauses at termination of A/D conversion for the next channel is started.  The A/D conversion pauses, A/D conversion for the next channel is started.  The A/D conversion pauses at the termination of A/D conversion for the end channel.  When the start trigger is inputted while A/D conversion pauses, A/D conversion for the start channel.  To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS1:BUSY).  This mode cannot be restarted during A/D conversion.  Note:  To change the conversion mode, perform at the stop state before starting the A/D conversion.  When the conversion mode is set to "not restartable" (other than MD1, MD0 = "00,p"), it cannot |  |  |
| bit5         | S10:<br>Resolution select<br>bit                | trigger) during A/D conversion.  This bit sets the resolution of the A/D conversion.  When set to "0": Set the resolution of the A/D conversion to 10-bit of A/D conversion data bits D9 to D0.  When set to "1": Set the resolution of the A/D conversion to 8-bit of A/D conversion data bits D7 to D0.  Note:  To change the S10 bit, perform at the stop state before starting the A/D conversion. When the S10 bit is changed after starting A/D conversion, the converted result stored in the A/D conversion data bit (D9 to D0) is invalid.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |

# 18.3.3 A/D Data Register (ADCR0/ADCR1)

The A/D data register (ADCR0/ADCR1) stores the digital value generated as the conversion result. The ADCR0 stores the lower 8-bit, and ADCR1 stores the most significant 2-bit of the conversion result. This register is rewritten each time the conversion complete and stores last conversion value normally.

#### ■ A/D Data Register (ADCR0/ADCR1)

Figure 18.3-4 A/D Data Register (ADCR0/ADCR1)



Table 18.3-4 Functions of A/D Data Register (ADCR0/ADCR1)

| Bit Name             |                                          | Function                                                                                                                                                                                                                                                                                         |  |
|----------------------|------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit15<br>to<br>bit10 | Undefined bits                           | 1 is always read at reading.                                                                                                                                                                                                                                                                     |  |
| bit9<br>to<br>bit0   | D9 to D0:<br>A/D conversion data<br>bits | These bits store the A/D conversion results.  When resolution set in 10 bits (S10=0):  Conversion data is stored in the 10 bits from D9 to D0.  When resolution set in 8 bits (S10=1):  Conversion data is stored in the 8 bits from D7 to D0. In this case, the read values of D9 and D8 are 1. |  |
|                      |                                          | <ul> <li>Note:</li> <li>Writing to this register is disabled.</li> <li>Use a word instruction (MOVW) to read the A/D conversion results stored in the A/D conversion data bits (D9 to D0).</li> </ul>                                                                                            |  |

# 18.3.4 A/D Setting Register (ADSR0/ADSR1)

A/D setting register (ADSR0/ADSR1) can set as following.

- Setting of A/D conversion time (sampling time and comparing time)
- Setting of sampling channel (starting channel and end channel)
- Displaying the present sampling channels

#### ■ A/D Setting Register (ADSR0/ADSR1)

Figure 18.3-5 A/D Setting Register (ADSR0/ADSR1)



Table 18.3-5 Function of A/D Setting Register (ADSR0/ADSR1) (1/2)

| Bit Name             |                                                              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
|----------------------|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit15<br>to<br>bit13 | ST2, ST1, ST0:<br>Sampling time select<br>bits               | <ul> <li>These bits set the sampling time of A/D conversion.</li> <li>These bits set the time when the A/D conversion is started and inputted analog voltage is sampled by the sample &amp; hold circuit until it is retained.</li> <li>See Table 18.3-6 for the setting of these bits.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| bit12<br>to<br>bit10 | CT2, CT1, CT0:<br>Comparing time<br>select bits              | <ul> <li>Comparing time of A/D conversion (comparing time) is set.</li> <li>These bits set the time when the analog input is A/D converted until it stores to the data bits (D9 to D0).</li> <li>See Table 18.3-7 for the setting of these bits.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| bit9,<br>bit4        | Reserved bits                                                | Always write 0 to these bits. Reading value is always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| bit8<br>to<br>bit5   | ANS3 to ANS0:<br>A/D conversion start<br>channel select bits | These bits set the channel at which A/D conversion start.At read, the channel number under conversion can be checked if the A/D conversion is in progress and last A/D converted channel number can be checked if the A/D conversion is completed or is stopping.  And before A/D conversion starts, the previous conversion channel will be read even if these bits have already been set to the new value. These bits are initialized to "0000 <sub>B</sub> " at reset.  Start channel < end channel:  A/D conversion starts at channel set by A/D conversion start channel select bits (ANS3 to ANS0) and terminates channel set by A/D conversion end channel select bits (ANE3 to ANE0)  Start channel = end channel:  A/D conversion is performed only for one channel set by A/D conversion start (= end) channel select bits (ANS3 to ANS0 = ANE3 to ANE0)  Start channel > end channel:  Do not set  Continuous conversion mode and pause-conversion mode:  When A/D conversion terminated at the channel set by the A/D conversion end channel select bits (ANE3 to ANE0), it returns to the channel set by the A/D conversion start channel select bits (ANS3 to ANS0).  Read (Other than pause-conversion mode):  The channel numbers (15 to 0) under A/D conversion are read.  Read (Pause-conversion mode):  At read during a pause, the channel number A/D-converted immediately before a pause is read.  Notes:  Do not set the A/D conversion start channel bits (ANS3 to ANS0) during A/D conversion.  Access in units of word when writing to these bits. If the byte write or bit operation is performed, the A/D conversion may be started from unexpected channel. |  |

Table 18.3-5 Function of A/D Setting Register (ADSR0/ADSR1) (2/2)

| Bit Name           |                                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|--------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit3<br>to<br>bit0 | ANE3 to ANE0:<br>A/D conversion end<br>channel select bits | These bits set the channel at which A/D conversion terminated.  Start channel < end channel:  A/D conversion starts at channel set by A/D conversion start channel select bits (ANS3 to ANS0) and terminates channel set by A/D conversion end channel select bits (ANE3 to ANE0)  Start channel = end channel:  A/D conversion is performed only for one channel set by A/D converter start (= end) channel select bits (ANE3 to ANE0 = ANS3 to ANS0).  Start channel > end channel:  Do not set.  Continuous conversion mode and pause-conversion mode:  When A/D conversion terminated at the channel set by the A/D conversion end channel select bits (ANE3 to ANE0), it returns to the channel set by the A/D conversion start channel select bits (ANS3 to ANS0).  Note:  Do not set the A/D conversion end channel select bits (ANE3 to ANE0) during A/D conversion. |

#### Note:

Do not set the A/D conversion mode set bits (MD1 and MD0) and A/D conversion end channel select bits (ANE3, ANE2, ANE1 and ANE0) through read-modify-write commands after the start channel is set in the A/D conversion start channel select bits (ANS3, ANS2, ANS1 and ANS0).

The ANS3, ANS2, ANS1 and ANS0 bits will read the last conversion channel until the A/D conversion operation starts. Accordingly when the MD1 and MD0 bits and the ANE3, ANE2, ANE1 and ANE0 bits are set through read-modify-write commands after the start channel is set in the ANS3, ANS2, ANS1 and ANS0 bits, the values of the ANE3, ANE2, ANE1 and ANE0 bits may be rewritten.

## ■ Setting of Sampling Time (ST2 to ST0 bits)

Table 18.3-6 Relation between ST2 to ST0 Bits and Sampling Time

| ST2 | ST1 | ST0 | Setting of Sampling<br>Time | Setting example (¢: Internal operating frequency) |
|-----|-----|-----|-----------------------------|---------------------------------------------------|
| 0   | 0   | 0   | 4 machine cycles            | φ= 8 MHz: 0.5 μs                                  |
| 0   | 0   | 1   | 6 machine cycles            | φ= 8 MHz: 0.75 μs                                 |
| 0   | 1   | 0   | 8 machine cycles            | φ= 16 MHz: 0.5 μs                                 |
| 0   | 1   | 1   | 12 machine cycles           | φ= 24 MHz: 0.5 μs                                 |
| 1   | 0   | 0   | 24 machine cycles           | φ= 8 MHz: 3 μs                                    |
| 1   | 0   | 1   | 36 machine cycles           | φ= 16 MHz: 2.25 μs                                |
| 1   | 1   | 0   | 48 machine cycles           | φ= 16 MHz: 3.0 μs                                 |
| 1   | 1   | 1   | 128 machine cycles          | φ= 24 MHz: 5.3 μs                                 |

The sampling time must be set according to drive impedance  $R_{ext}$  connected to analog input. If the following condition is not met, the conversion accuracy will not be guaranteed.

- $R_{ext} \le 1.5 k\Omega$ :
  - •- 4.5 V  $\leq$  AV<sub>CC</sub> < 5.5 V: The sampling time must be set greater than 0.5  $\mu$ s.
  - 4.0 V  $\leq$  AV  $_{CC}$  < 4.5 V: The sampling time must be set greater than 1.2  $\mu s.$
- $R_{ext} > 1.5 k\Omega$ : The sampling time must be set greater than  $T_{samp}$  given by the following formula.
  - 4.5 V  $\leq$  AV<sub>CC</sub> < 5.5 V: T<sub>samp</sub> = (2.52 k $\Omega$ +R<sub>ext</sub>)  $\times$  10.7 pF  $\times$  7
  - 4.0 V  $\leq$  AV<sub>CC</sub> < 4.5 V:  $T_{samp} = (13.6 \text{ k}\Omega + R_{ext}) \times 10.7 \text{ pF} \times 7$

#### ■ Setting of Comparing Time (CT2 to CT0 bits)

Table 18.3-7 Relation between CT2 to CT0 Bits and Comparing Time

| CT2 | CT1 | СТ0 | Setting of comparing time | Setting example (¢: Internal operating frequency) |
|-----|-----|-----|---------------------------|---------------------------------------------------|
| 0   | 0   | 0   | 22 machine cycles         | φ= 20 MHz: 1.1 μs                                 |
| 0   | 0   | 1   | 33 machine cycles         | φ= 24 MHz: 1.4 μs                                 |
| 0   | 1   | 0   | 44 machine cycles         | φ= 24 MHz: 1.8 μs                                 |
| 0   | 1   | 1   | 66 machine cycles         | φ= 24 MHz: 2.75 μs                                |
| 1   | 0   | 0   | 88 machine cycles         | φ= 8 MHz: 11.0 μs                                 |
| 1   | 0   | 1   | 132 machine cycles        | φ= 16 MHz: 8.25 μs                                |
| 1   | 1   | 0   | 176 machine cycles        | φ= 20 MHz: 8.8 μs                                 |
| 1   | 1   | 1   | 264 machine cycles        | φ= 24 MHz: 11.0 μs                                |

The comparing time must be set according to the analog power supply voltage AV<sub>CC</sub>. If the following condition is not met, the conversion accuracy will not be guaranteed.

- $4.5 \text{ V} \le \text{AV}_{CC} < 5.5 \text{ V}$ : The comparing time must be set greater than  $1.00 \ \mu s$ .
- $4.0~V \le AV_{CC} < 4.5~V$ : The comparing time must be set greater than  $2.00~\mu s$ .

# 18.3.5 Analog Input Enable Register (ADER5, ADER6)

The analog input enable register enables or disables the analog input pins to be used in the 8-/10-bit A/D converter.

#### ■ Analog Input Enable Register (ADER5, ADER 6)

Figure 18.3-6 Analog Input Enable Register (ADER5 to 6)



Table 18.3-8 Functions of Port 5 Analog Input Enable Register (ADER5)

| Bit Name            |                                                       | Function                                                                                                                                                                            |
|---------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15<br>to<br>bit8 | ADE15 to ADE8:<br>Analog input enable<br>bits 15 to 8 | These bits enable or disable the analog input pin (AN15 to AN8) of A/D conversion arranged on port 5.  When set to "0": Disables analog input When set to "1": Enables analog input |

Table 18.3-9 Functions of Port 6 Analog Input Enable Register (ADER6)

| Bit Name           |                                                     | Function                                                                                                                                                                           |
|--------------------|-----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit0<br>to<br>bit7 | ADE7 to ADE0:<br>Analog input enable<br>bits 7 to 0 | These bits enable or disable the analog input pin (AN7 to AN0) of A/D conversion arranged on port 6.  When set to "0": Disables analog input When set to "1": Enables analog input |

#### **Notes:**

- When using as the analog input pin, write "1" to the bit of the analog input enable register (ADER5, ADER6) corresponding to the pin to be used and set to the analog input.
- Setting the analog input pin to ADERx = "0" is disabled. Always set it to ADERx = "1".
- Each analog input pin serves as the general-purpose I/O port and I/O of peripheral function. The pin set to ADERx = "1" is forcibly set to the analog input pin regardless of the port direction register (DDR5, DDR6) and the I/O setting of each peripheral function.

# 18.4 Interrupt of 8-/10-bit A/D Converter

When A/D conversion is terminated and its results are stored in the A/D data register (ADCR), the 8-/10-bit A/D converter generates an interrupt request. The El<sup>2</sup>OS function can be used.

#### ■ Interrupt of A/D Converter

When A/D conversion of the analog input voltage is terminated and its results are stored in the A/D data register (ADCR), the interrupt request flag bit in the A/D control status register (ADCS:INT) is set to "1". When the interrupt request flag bit is set (ADCS:INT = 1) with an interrupt request output enabled (ADCS:INTE = 1), an interrupt request is generated.

## ■ 8-/10-bit A/D Converter Interrupt and El<sup>2</sup>OS

Reference: See "CHAPTER 3 INTERRUPTS" for details of the interrupt number, interrupt control register, and interrupt vector address.

## ■ El<sup>2</sup>OS Function of 8-/10-bit A/D Converter

In the 8-/10-bit A/D converter, the  $EI^2OS$  function can be used to transfer the A/D conversion results from the A/D data register (ADCR) to memory. If the  $EI^2OS$  function is used, the A/D-converted data protection function is activated to cause A/D conversion to pause during memory transfer and prevent data loss as A/D conversion is performed continuously.

## 18.5 Explanation of Operation of 8-/10-bit A/D Converter

The 8-/10-bit A/D converter has the following A/D conversion modes. Set each mode according to the setting of the A/D conversion mode select bits in the A/D control status register (ADCS:MD1, MD0).

- Single-shot conversion mode (restartable/not-restartable during A/D conversion)
- Continuous conversion mode (not-restartable during A/D conversion)
- Pause--conversion mode (not-restartable during A/D conversion)

#### ■ Single-shot Conversion Mode (ADCS: MD1, MD0="00<sub>B</sub>" or "01<sub>B</sub>")

- When the start trigger is inputted, the analog inputs from the start channel (ADCS:ANS3 to ANS0) to the end channel (ADCS:ANE3 to ANE0) are A/D-converted continuously.
- The A/D conversion stops at the termination of the A/D conversion for the end channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- When the A/D conversion mode select bits (MD1, MD0) are set to "00<sub>B</sub>", this mode can be restarted during A/D conversion. If the bits are set to "01<sub>B</sub>", this mode cannot be restarted during A/D conversion.

#### ■ Continuous Conversion Mode (ADCS: MD1, MD0="10<sub>B</sub>")

- When the start trigger is inputted, the analog inputs from the start channel (ADCS:ANS3 to ANS0) to the end channel (ADCS:ANE3 to ANE0) are A/D-converted continuously.
- When A/D conversion for the end channel is terminated, it is continued after returning to the analog input for the start channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- This mode cannot be restarted during A/D conversion.

#### ■ Pause-conversion Mode (ADCS: MD1, MD0="11<sub>B</sub>")

- When the start trigger is inputted, A/D conversion starts for the start channel (ADCS:ANS3 to ANS0). The A/D conversion pauses at the termination of A/D conversion for one channel. When the start trigger is inputted while A/D conversion pauses, A/D conversion is performed for the next channel.
- The A/D conversion pauses at termination of A/D conversion for the end channel. When the start trigger is inputted while A/D conversion pauses, A/D conversion is continued after returning to the analog input for the start channel.
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- This mode cannot be restarted during A/D conversion.

# 18.5.1 Single-shot Conversion Mode

In the single-shot conversion mode, A/D conversion is performed sequentially from the start channel to the end channel. The A/D conversion stops at the termination of A/D conversion for the end channel.

#### ■ Setting of Single-shot Conversion Mode

Operating the 8-/10-bit A/D converter in the single-shot conversion mode requires the setting shown in Figure 18.5-1 .

bit15 14 13 12 11 10 9 bit8 bit7 6 bit0 5 1 Re-served BUSY INT INTE PAUS STS1 STS0 STRT **ADCS** MD1 MD0 S10 0 0 0 0 0 0 0 **ADCR** D9 to D0 (Converted data stored) ANS3 ANS2 ANS1 ANS0 Re-**ADSR** ANE3|ANE2|ANE1|ANE0 ADE15ADE14ADE13ADE12ADE11ADE10|ADE9 |ADE8 ADER5 O ADER6 : Undefined : Used bit : Set the bit corresponding to pin to be used as analog input pin to 1. : Setting 0

Figure 18.5-1 Setting of Single-shot Conversion Mode

#### **■** Operation of Single-shot Conversion Mode

- When the start trigger is inputted, A/D conversion starts from the channel set by the A/D conversion start channel select bits (ANS3 to ANS0) and is performed continuously up to the channel set by the A/D conversion end channel select bits (ANE3 to ANE0).
- The A/D conversion stops at the termination of the A/D conversion for the channel set by the A/D conversion end channel select bits (ANE3 to ANE0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- When the A/D conversion mode select bits (MD1, MD0) are set to "00<sub>B</sub>", this mode can be restarted during A/D conversion. If the bits are set to "01<sub>B</sub>", this mode cannot be restarted during A/D conversion.

#### [When start and end channels are the same]

If the start and end channels have the same channel number (ADCS: ANS3 to ANS0=ADCS: ANE3 to ANE0), only one A/D conversion for one channel set as the start channel (= end channel) is performed and terminated.

#### [Conversion order in single-shot conversion mode]

Table 18.5-1 gives an example of the conversion order in the single-shot conversion mode.

Table 18.5-1 Conversion Order in Single-shot Conversion Mode

| Start Channel                               | End Channel                                 | Conversion Order                                                      |
|---------------------------------------------|---------------------------------------------|-----------------------------------------------------------------------|
| AN0 pin<br>(ADCS: ANS="0000 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="0011 <sub>B</sub> ") | $AN0 \rightarrow AN1 \rightarrow AN2 \rightarrow AN3 \rightarrow end$ |
| AN3 pin<br>(ADCS: ANS="0011 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="0011 <sub>B</sub> ") | $AN3 \rightarrow end$                                                 |

### 18.5.2 Continuous Conversion Mode

In the continuous conversion mode, A/D conversion is performed sequentially from the start channel to the end channel. When A/D conversion for the end channel is terminated, it is continued after returning to the start channel.

#### ■ Setting of Continuous Conversion Mode

Operating the 8-/10-bit A/D converter in the continuous conversion mode requires the setting shown in Figure 18.5-2.

bit15 14 13 12 11 10 9 bit8 bit7 6 5 1 bit0 BUSY INT INTE PAUS STS1 STS0 STRT **ADCS** MD1 MD0 S10 0 0 0 0 0 0 **ADCR** D9 to D0 (Converted data stored) ST2 ST1 ST0 CT2 CT1 CT0 Re- ANS3 ANS2 ANS1 ANS0 Re- served **ADSR** |ANE3|ANE2|ANE1|ANE0 0 0 0 ADE15|ADE14|ADE13|ADE12|ADE11|ADE10| ADE9 | ADE8 ADER5 ADER6 ADE7 ADE6 ADE5 ADE4 ADE3 ADE2 ADE1 ADE0 : Undefined O: Used bit O: Set the bit corresponding to pin to be used as analog input pin to 1. 1 : Setting 1 0 : Setting 0

Figure 18.5-2 Setting of Continuous Conversion Mode

#### **■** Operation of Continuous Conversion Mode

- When the start trigger is inputted, A/D conversion starts from the channel set by the A/D conversion start channel select bits (ANS3 to ANS0) and is performed continuously up to the channel set by the A/D conversion end channel select bits (ANE3 to ANE0).
- When A/D conversion for the channel set by the A/D conversion end channel select bits (ANE3 to ANE0) is terminated, it is continued after returning to the channel set by the A/D conversion start channel select bits (ANS3 to ANS0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- This mode cannot be restarted during A/D conversion.

#### [When start and end channels are the same]

If the start and end channels have the same channel number (ADCS:ANS3 to ANS0 = ADCS:ANE3 to ANE0), A/D conversion for one channel set as the start channel (= end channel) is repeated.

#### [Conversion order in continuous conversion mode]

Table 18.5-2 gives an example of the conversion order in the continuous conversion mode.

Table 18.5-2 Conversion Order in Continuous Conversion Mode

| Start Channel                               | End Channel                                 | Conversion Order                                                                         |
|---------------------------------------------|---------------------------------------------|------------------------------------------------------------------------------------------|
| AN0 pin<br>(ADCS: ANS="0000 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="0011 <sub>B</sub> ") | $AN0 \rightarrow AN1 \rightarrow AN2 \rightarrow AN3 \rightarrow AN0 \rightarrow$ repeat |
| AN3 pin<br>(ADCS: ANS="0011 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="0011 <sub>B</sub> ") | $AN3 \rightarrow AN3 \rightarrow repeat$                                                 |

#### 18.5.3 Pause-conversion Mode

In the pause-conversion mode, A/D conversion starts and pauses repeatedly for each channel. When the start trigger is inputted after the A/D conversion pauses at the termination of the A/D conversion for the end channel, A/D conversion is continued after returning to the start channel.

#### ■ Setting of Pause-conversion Mode

Operating the 8-/10-bit A/D converter in the pause-conversion mode requires the setting shown in Figure 18.5-3.

bit15 14 13 12 11 10 9 bit8 bit7 6 bit0 Re-**ADCS** BUSY INT INTE PAUS STS1 STS0 STRT MD1 MD0 S10 **ADCR** D9 to D0 (Converted data stored) ST2|ST1|ST0|CT2|CT1|CT0|<sub>served</sub> lans3lans2lans1lans0l ANE3IANE2IANE1IANE0 **ADSR** ADER5 ADE15ADE14ADE13ADE12ADE11ADE10ADE9 0 0 0 0 ADE7 ADE6 ADE5 ADE4 ADE3 ADE2 ADE1 ADE0 ADER6 - : Undefined O: Used bit O: Set the bit corresponding to pin to be used as analog input pin to 1. 1 : Setting 1 0 : Setting 0

Figure 18.5-3 Setting of Pause-conversion Mode

#### **■** Operation of Pause-conversion Mode

- When the start trigger is inputted, A/D conversion starts at the channel set by the A/D conversion start channel select bits (ANS3 to ANS0). The A/D conversion pauses at the termination of the A/D conversion for one channel. When the start trigger is inputted while A/D conversion pauses, A/D conversion for the next channel is performed.
- The A/D conversion pauses at the termination of the A/D conversion for the channel set by the A/D conversion end channel select bits (ANE3 to ANE0). When the start trigger is inputted while A/D conversion pauses, A/D conversion is continued after returning to the channel set by the A/D conversion start channel select bits (ANS3 to ANS0).
- To restart this mode while A/D conversion pauses, input the start trigger set by the A/D start trigger select bits in the A/D control status register (ADCS:STS1, STS0).
- To terminate A/D conversion forcibly, write 0 to the A/D conversion-on flag bit in the A/D control status register (ADCS:BUSY).
- This mode cannot be restarted during A/D conversion.

#### [When start and end channels are the same]

If the start and end channels have the same channel number (ADCS:ANS3 to ANS0 = ADCS:ANE3 to ANE0), A/D conversion for one channel set as the start channel (= end channel) and pause are repeated.

#### [Conversion order in pause-conversion mode]

Table 18.5-3 gives an example of the conversion order in the pause-conversion mode.

Table 18.5-3 Conversion Order in Pause-conversion Mode

| Start Channel                               | End Channel                                 | Conversion Order                                                                                                                                                                         |
|---------------------------------------------|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AN0 pin<br>(ADCS: ANS="0000 <sub>B</sub> ") | AN3 pin<br>(ADCS: ANE="0011 <sub>B</sub> ") | $AN0 \rightarrow Stop, Start \rightarrow AN1 \rightarrow Stop, Start \rightarrow AN2 \rightarrow Stop, Start \rightarrow AN3 \rightarrow Stop, Start \rightarrow AN0 \rightarrow Repeat$ |
| AN3 pin (ADCS: ANS="0011 <sub>B</sub> ")    | AN3 pin (ADCS: ANE="0011 <sub>B</sub> ")    | $AN3 \rightarrow Stop, Start \rightarrow AN3 \rightarrow Stop, Start \rightarrow$<br>Repeat                                                                                              |

# 18.5.4 Conversion Using El<sup>2</sup>OS Function

The 8-/10-bit A/D converter can transfer the A/D conversion result to memory by using the El<sup>2</sup>OS function.

## ■ Conversion Using El<sup>2</sup>OS

The use of the  $EI^2OS$  enables the A/D-converted data protection function to transfer multiple data to memory without the loss of converted data even if A/D conversion is performed continuously.

The conversion flow when the EI<sup>2</sup>OS is used is shown in Figure 18.5-4.

A/D converter starts Sample & hold A/D conversion starts A/D conversion terminates Interrupt generated El<sup>2</sup>OS starts Converted data transferred NO Specified count completed? Interrupt cleared YES Interrupt processing \*: The specified count depends on the setting of the El<sup>2</sup>OS.

Figure 18.5-4 Flow of Conversion when Using El<sup>2</sup>OS

#### 18.5.5 A/D-converted Data Protection Function

A/D conversion with the output of an interrupt request enabled activates the A/D conversion data protection function.

#### ■ A/D-converted Data Protection Function in 8-/10-bit A/D Converter

The 8-/10-bit A/D converter has only one A/D data register (ADCR) where A/D-converted data is stored. When the A/D conversion results are determined after the termination of A/D conversion, data in the A/D data register is rewritten. Therefore, the A/D conversion results may be lost if the A/D conversion results already stored are not read before data in the A/D data register is rewritten. The A/D-converted data protection function in the 8-/10-bit A/D converter is activated to prevent data loss. This function automatically causes A/D conversion to pause when an interrupt request is generated (ADCS:INT = 1) with an interrupt request enabled (ADCS:INTE = 1).

#### A/D-converted data protection function when El<sup>2</sup>OS not used

- When the A/D conversion results are stored in the A/D data register (ADCR) after the analog input is A/D-converted, the interrupt request flag bit in the A/D control status register (ADCS: INT) is set to "1".
- The A/D conversion stops for data protection immediately before new data is overwritten to the A/D data register if the interrupt request is enabled (ADCS: INTE = 1) while the interrupt request flag bit set at termination of previous A/D conversion is set at the point that next A/D conversion is terminated.
- When the INT bit is set with an interrupt request from the A/D control status register enabled (ADCS: INTE = 1), an interrupt request is generated. When the INT bit is cleared by the generated interrupt processing, the pause of A/D conversion is cancelled.

#### A/D-converted data protection function when El<sup>2</sup>OS used

- The A/D conversion stops for data protection immediately before new data is overwritten to the A/D data register while the EI<sup>2</sup>OS function is used to transfer the A/D conversion results from the A/D data register to memory when next A/D conversion is terminated. When A/D conversion pauses, the pause flag bit in the A/D control status register (ADCS: PAUS) is set to "1".
- When the transfer of the A/D conversion results to memory by the EI<sup>2</sup>OS function is terminated, the pause of A/D conversion is cancelled. If the A/D conversion is performed continuously, it is restarted. In this case, the pause flag bit (ADCS:PAUS) is not cleared to "0" automatically. Clearing this bit writes 0 to it.

#### Processing flow of A/D conversion data protection function when El<sup>2</sup>OS used

Figure 18.5-5 shows the processing flow of the A/D conversion data protection function when the EI<sup>2</sup>OS is used.



Figure 18.5-5 Processing Flow of A/D Conversion Data Protection Function when Using El<sup>2</sup>OS

#### **Notes:**

- The A/D conversion data protection function is activated only when an interrupt request is enabled. Set the interrupt request enable bit in the A/D control status register (ADCS:INTE) to 1.
- The EI<sup>2</sup>OS function is used to transfer the A/D conversion results to memory, do not disable output of an interrupt request. If output of an interrupt request is disabled during a pause of A/D conversion (ADCS:INTE = 0), A/D conversion may be restarted to rewrite data being transferred.
- The EI<sup>2</sup>OS function is used to transfer the A/D conversion results to memory, do not restart. Restarting during a pause of A/D conversion may cause loss of the A/D conversion results.

# 18.6 Precautions when Using 8-/10-bit A/D Converter

#### Precautions when using the 8-/10-bit A/D converter are given below:

#### ■ Precautions when Using 8-/10-bit A/D Converter

#### Analog input pin

- The analog input pins serve as general-purpose I/O ports of port 5 and port 6. When using the pin as an analog input pin, switch the pin to "analog input pin" according to the setting of the analog input enable register (ADER5, ADER6).
- When using the pin as an analog input pin, write 1 to the bit in the analog input enable register (ADER5, ADER6) corresponding to the pin to be used and set the pin to "analog input enable".
- When an intermediate-level signal is inputted with the pin set as a general-purpose I/O port, the input leakage current flows in the gate. When using the pin as an analog input pin, always set the pin to "analog input enable".

#### Precaution when starting by external trigger

• Set the level of the external trigger to inactive ("H" for external trigger) when the A/D start trigger select bits in the A/D control status register (ADCS: STS1 and STS0) is set the same way as starting the 8-/10-bit A/D converter by the external trigger. Holding the input value for the start trigger active may cause the 8-/10-bit A/D converter to start the A/D start trigger select bits in the A/D control status register (ADCS: STS1 and STS0).

#### Procedure of 8-/10-bit A/D converter and analog input power-on

- Always apply a power to the 8-/10-bit A/D converter power (AV CC, AVR) and the analog input (AN0 to AN15 pins) after or concurrently with the digital power (V<sub>CC</sub>)-on.
- Always turn off the 8-/10-bit A/D converter power and the analog input before or concurrently with the digital power ( $V_{CC}$ )-down.
- Note that AVR should not exceed AV<sub>CC</sub> at power on or power down. (Turning on and off the analog power and digital power simultaneously is enabled.)

#### Power supply voltage of 8-/10-bit A/D converter

• To prevent latch up, note that the 8-/10-bit A/D converter power (AV<sub>CC</sub>) should not exceed the digital power (V<sub>CC</sub>) voltage.

# CHAPTER 19

# LOW VOLTAGE DETECTION/ CPU OPERATING DETECTION RESET

This chapter explains the function and operating the low voltage detection/CPU operating detection reset. This function can use only the product with "T" suffix of MB90360 series.

- 19.1 Overview of Low Voltage/CPU Operating Detection Reset Circuit
- 19.2 Configuration of Low Voltage/CPU Operating Detection Reset Circuit
- 19.3 Low Voltage/CPU Operating Detection Reset Circuit Register
- 19.4 Operating of Low Voltage/CPU Operating Detection Reset Circuit
- 19.5 Notes on Using Low Voltage/CPU Operating Detection Reset
- 19.6 Sample Program for Low Voltage/CPU Operating Detection Reset Circuit

# 19.1 Overview of Low Voltage/CPU Operating Detection Reset Circuit

The low voltage detection reset circuit watches the power-supply voltage and has the function to detect the power-supply voltages falling lower than the detection voltage values. When the low voltage is detected, internal reset is generated.

When the counter is not cleared within the fixed time after 20-bit counter start that makes the oscillation clock a count clock, CPU operating detection reset circuit generates internal reset.

#### ■ Low Voltage Detection Reset Circuit

Figure 19.1-1 Detection Voltage of Low Voltage/CPU operating Detection Reset Circuit



After detecting the low voltage, low voltage detection flag (LVRC:LVRF) is set to "1", and internal reset is outputted.

After the low voltage is detected, internal reset is generated and the STOP mode is canceled, because of that keep operating at the STOP mode.

After writing ends, low voltage reset is generated for internal RAM writing period.

#### **■ CPU Operating Detection Reset Circuit**

CPU operating detection reset circuit is a counter for preventing the program out of control. After power-on reset, it starts automatically. After it starts, it is necessary to keep clearing regularly within the fixed time. Internal reset is generated when not cleared during the fixed time by an program infinite loop, etc. The width of internal reset generated by CPU operating detection circuit is five machine cycles.

Figure 19.1-2 Interval Time of CPU operating Detection Reset Circuit



In the mode that CPU stops operating, the circuit stops.

The counter condition of CPU operating detection reset circuit is indicated as follows.

- 1) Writing "0" to CL bit of LVRC register
- 2) Internal reset
- 3) Oscillation clock stop
- 4) Transition to sleep mode
- 5) Transition to timebase timer mode

#### 19.2 Configuration of Low Voltage/CPU Operating Detection **Reset Circuit**

Low voltage/CPU operating detection reset circuit has following three blocks.

- CPU operating detection circuit
- Voltage comparison circuit
- Low voltage/CPU operating detection reset control register (LVRC)

#### ■ Block Diagram of Low Voltage/CPU Operating Detection Reset Circuit

Voltage comparison circuit Fixed voltage supply CPU operating detection circuit Oscillation clock Counter Internal reset Noise canceler Clear LVRF Reserved CPUF CL Reserved Reserved Reserved Low voltage/CPU operating detection reset control register (LVRC) Internal data bus

Figure 19.2-1 Block Diagram of Low Voltage/CPU operating Detection Reset Circuit

#### CPU operating detection circuit

It is a counter for preventing the program out of control. After it starts, it is necessary to keep clearing regularly within the fixed time.

#### Voltage comparison circuit

When the detection voltage is compared with the power-supply voltage, the output is set to "H" after the low voltage detection.

After the power supply is turned on, it always operates.

#### Low voltage/CPU operating detection reset control register (LVRC)

This register clears the low voltage/CPU operating detection reset flag and the counter of CPU operating detection function.

#### Reset factor of low voltage/CPU operating detection reset circuit

After power-supply voltages is fallen more than the detection voltages, internal reset is generated.

When the counter of CPU operating detection circuit is not cleared during the fixed time, internal reset is generated.

# 19.3 Low Voltage/CPU Operating Detection Reset Circuit Register

This register clears the low voltage/CPU operating detection reset flag and the counter of CPU operating detection circuit.

#### ■ Low Voltage/CPU Operating Detection Reset Control Register (LVRC)



Table 19.3-1 Functional Description of Low Voltage/CPU operating Detection Reset Control Register

|               | Bit name                                    | Function                                                                                                                                                                                                                                                                                                     |  |
|---------------|---------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| bit7/<br>bit6 | Reserved:<br>Reserved bits                  | Note: These bits should write "0".                                                                                                                                                                                                                                                                           |  |
| bit5/<br>bit4 | Reserved:<br>Reserved bits                  | Note: These bits should write "1".                                                                                                                                                                                                                                                                           |  |
| bit3          | CL:<br>CPU operating<br>detection clear bit | This bit is a bit that clears the counter of CPU operating detection circuit. When "0" is written in the CL bit, the counter of CPU operating detection circuit is cleared.                                                                                                                                  |  |
| bit2          | LVRF:<br>Low voltage<br>detection flag bit  | When falling of the power-supply voltage is detected, the LVRF bit is set to "1". This bit is cleared by "0" at write. And even if "1" is written in this bit, the LVRF bit is no effect. This bit is not initialized in internal reset, and it is initialized only by the external reset input.             |  |
| bit1          | Reserved:<br>Reserved bit                   | Note: This bit should write "0".                                                                                                                                                                                                                                                                             |  |
| bit0          | CPUF:<br>CPU                                | When the counter of CPU operating detecting function overflows, the CPUF bit is set to "1".  This bit is cleared by "0" at write. And even if "1" is written in this bit, the CPUF bit is no effect.  This bit is not initialized in internal reset, and it is initialized only by the external reset input. |  |

# 19.4 Operating of Low Voltage/CPU Operating Detection Reset Circuit

The circuit watches the power-supply voltage. When the power supply voltage is lower than the set value, internal reset is generated. In CPU operating detecting function, internal reset is generated without the counter clear at constant intervals. When internal reset is generated by the detection of the low voltage or the out of CPU control, the content of the register is not guaranteed. The program restarts from the address specified by the reset vector after the reset sequence is executed when the low voltage reset is canceled.

#### ■ Operating of Low Voltage/CPU Operating Detection Reset Circuit

The low voltage detection reset circuit starts the detection of the low voltage without taking the operating stability wait time after reset is canceled.

#### ■ Operating of CPU Operating Detection Reset Circuit

The CPU operating detection reset circuit starts the detection of the CPU operation without taking the operating stability wait time after reset is canceled.

#### Note:

The current is consumed during the sleep or stop mode because the low voltage reset circuit always operates.

# 19.5 Notes on Using Low Voltage/CPU Operating Detection Reset Circuit

This section explains the note on using the low voltage/CPU operating detection reset circuit.

#### ■ Notes on Using Low Voltage Detection Reset Circuit

Disabled operating stop from program

The low voltage detection reset circuit operates continuously after the power supply is turned on and the operating stabilization wait time passes. Operating can not be stopped with software.

Operating at STOP mode

Low voltage detection reset keeps operating at the STOP mode. Therefore, if a low voltage is detected in the STOP mode, reset is generated and the STOP mode is canceled.

#### ■ Notes on Using CPU Operating Detection Reset Circuit

Disabled operating stop from program

CPU operating detection reset circuit operates continuously after turning on the power supply. Operating cannot be stopped with software.

Reset generation control of CPU operating detecting function

CPU operating detecting function should clear the counter at regular intervals. The counter is cleared by writing "0" to the CL bit of the LVRC register, and the reset generation can be controlled.

Stop and clear of counter

In the mode CPU stops operating, CPU operating detecting function clears the counter and stops operating.

Operation in sub-oscillation mode

The CPU operation detection function will stop operation in sub-oscillation mode. For this reason, also use the watchdog reset function.

# 19.6 Sample Program for Low Voltage/CPU Operating Detection Reset Circuit

This section shows the sample program for low voltage/CPU operating detection reset circuit.

#### ■ Sample Program for Low Voltage/CPU Operating Detection Reset Circuit

Processing specification

The counter of CPU operating detecting function is cleared.

Coding example

# CHAPTER 20 LIN-UART

This chapter explains the functions and operation of LIN-UART.

- 20.1 Overview of LIN-UART
- 20.2 Configuration of LIN-UART
- 20.3 LIN-UART Pins
- 20.4 LIN-UART Registers
- 20.5 LIN-UART Interrupts
- 20.6 LIN-UART Baud Rates
- 20.7 Operation of LIN-UART
- 20.8 Notes on Using LIN-UART

### 20.1 Overview of LIN-UART

The LIN-UART with LIN (Local Interconnect Network) - Function is a general-purpose serial data communication interface for performing synchronous or asynchronous communication (start-stop synchronization) with external devices. LIN-UART provides bidirectional communication function (normal mode), master-slave communication function (multiprocessor mode in master/slave systems), and special features for LIN-bus systems.

### **■ LIN-UART Functions**

#### LIN-UART functions

LIN-UART is a general-purpose serial data communication interface for transmitting serial data to and receiving data from another CPU and peripheral devices. It has the functions listed in Table 20.1-1.

Table 20.1-1 LIN-UART Functions (1/2)

|                                                                | Function                                                                                                                                                                                                                                                                                                       |  |
|----------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data buffer                                                    | Full-duplicate double-buffer                                                                                                                                                                                                                                                                                   |  |
| Serial input                                                   | Perform oversampling 5 times and determine the received value by majority decision of sampling time (asynchronous mode only)                                                                                                                                                                                   |  |
| Transfer mode                                                  | <ul> <li>Synchronous to clock (selecting start/stop synchronous or start/stop bit)</li> <li>Asynchronous (start/stop bits can be used.)</li> </ul>                                                                                                                                                             |  |
| Baud rate                                                      | <ul> <li>Dedicated baud-rate generator (The baud rate is consisted of 15-bit reload counter.)</li> <li>An external clock can be inputted and also be adjusted by reload counter.</li> </ul>                                                                                                                    |  |
| Data length                                                    | <ul><li> 7 bits (other than synchronous or LIN mode)</li><li> 8 bits</li></ul>                                                                                                                                                                                                                                 |  |
| Signal type                                                    | NRZ (Non Return to Zero)                                                                                                                                                                                                                                                                                       |  |
| Start bit timing                                               | Synchronization to the falling edge of the start bit in the asynchronous mode                                                                                                                                                                                                                                  |  |
| Detection of receive error                                     | Framing error                                                                                                                                                                                                                                                                                                  |  |
|                                                                | <ul> <li>Overrun error</li> <li>Parity error (not supported for operation mode 1)</li> </ul>                                                                                                                                                                                                                   |  |
| Interrupt request                                              | <ul> <li>Receive interrupt (receive termination, detection of receive error, LIN Synch break detection)</li> <li>Transmit interrupt (transmit data empty)</li> <li>Interrupt request to ICU (LIN Synch field detection: LSYN)</li> <li>Both the transmission and reception support EI<sup>2</sup>OS</li> </ul> |  |
| Master/slave type communication function (multiprocessor mode) | This function enables communication between 1 (only use master) and n (slave) (This function supports for the both of master and slave system.)                                                                                                                                                                |  |
| Synchronous mode                                               | Master of slave function                                                                                                                                                                                                                                                                                       |  |
| Pin access                                                     | Capable of reading the state of serial I/O pin directly                                                                                                                                                                                                                                                        |  |

Table 20.1-1 LIN-UART Functions (2/2)

|                          | Function                                                                                                                                                                                                                                        |
|--------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LIN bus option           | <ul> <li>Master device operation</li> <li>Slave device operation</li> <li>LIN Synch break detection</li> <li>LIN Synch break generation</li> <li>Detection of start/stop edges in LIN Synch field connected to input capture 0 and 1</li> </ul> |
| Synchronous serial clock | Synchronous serial clock can be continuously outputted to SCK pin for synchronous communication with start/stop bits.                                                                                                                           |
| Clock delay option       | Special synchronous clock mode for delaying clock (useful to SPI)                                                                                                                                                                               |

### **■ LIN-UART operation modes**

The LIN-UART operates in four different modes, which are determined by the MD0- and the MD1-bit of the serial mode register (SMR). Mode 0 and 2 are used for bidirectional serial communication, mode 1 for master/slave communication and mode 3 for LIN master/slave communication.

Table 20.1-2 Operation Mode of LIN-UART

|   | Operation Mode         | Mode Data Length |             | Synchronous/<br>Asynchronous | Length of<br>Stop Bit     | Data Bit Format |
|---|------------------------|------------------|-------------|------------------------------|---------------------------|-----------------|
|   |                        | No Parity        | With Parity | Asynchionous                 | Otop Bit                  |                 |
| 0 | Normal mode            | 7 or 8 bits      |             | Asynchronous                 | 1 bit or 2 bits           | LSB first       |
| 1 | Multiprocessor<br>mode | 7 or 8 bits-+1 * | -           | Asynchronous                 |                           | MSB first       |
| 2 | Normal mode            | 8                |             | Synchronous                  | None,<br>1 bit,<br>2 bits |                 |
| 3 | LIN mode               | 8                | -           | Asynchronous                 | 1 bit                     | LSB first       |

<sup>-:</sup> Setting disabled

The MD1 and MD0 bits of the serial mode register (SMR) determine the operation mode of LIN-UART as shown in the following table:

Table 20.1-3 Operation Mode of LIN-UART

| MD1 | MD0 | Mode | Туре                               |
|-----|-----|------|------------------------------------|
| 0   | 0   | 0    | Asynchronous (normal mode)         |
| 0   | 1   | 1    | Asynchronous (multiprocessor mode) |
| 1   | 0   | 2    | Synchronous (normal mode)          |
| 1   | 1   | 3    | Asynchronous (LIN mode)            |

#### Note:

Mode 1 operation is supported both for master or slave operation of LIN-UART in a master-slave connection system. In Mode 3 the LIN-UART function is locked to 8N1-Format, LSB first.

If the mode is changed, LIN-UART cuts off all possible transmission or reception and awaits then new action.

<sup>\*: +1</sup> is the address/data select bit (A/D) used for controlling communication in multiprocessor mode.

### ■ LIN-UART interrupt and El<sup>2</sup>OS

Table 20.1-4 LIN-UART Interrupt and El<sup>2</sup>OS

| Channel                   | Interrupt             | Interrupt Interrupt control register |                     | Vector table address |                     |                     | El <sup>2</sup> OS |
|---------------------------|-----------------------|--------------------------------------|---------------------|----------------------|---------------------|---------------------|--------------------|
|                           | number                | Register name                        | Address             | Lower                | Upper               | Bank                |                    |
| LIN-UART0 reception       | #35(23 <sub>H</sub> ) | ICR12                                | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub>  | FFFF71 <sub>H</sub> | FFFF72 <sub>H</sub> | *1                 |
| LIN-UART0<br>transmission | #36(24 <sub>H</sub> ) | ICR12                                | 0000BC <sub>H</sub> | FFFF6C <sub>H</sub>  | FFFF6D <sub>H</sub> | FFFF6E <sub>H</sub> | *2                 |
| LIN-UART1 reception       | #37(25 <sub>H</sub> ) | ICR13                                | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub>  | FFFF69 <sub>H</sub> | FFFF6A <sub>H</sub> | *1                 |
| LIN-UART1<br>transmission | #38(26 <sub>H</sub> ) | ICR13                                | 0000BD <sub>H</sub> | FFFF64 <sub>H</sub>  | FFFF65 <sub>H</sub> | FFFF66 <sub>H</sub> | *2                 |

<sup>\*1:</sup> EI<sup>2</sup>OS service is usable if the other interrupt (s) which shares the ICR12 to ICRB and same interrupt vector is (are) not enabled. Detection of receive errors is possible and stop function for EI<sup>2</sup>OS service is supported.

<sup>\*2:</sup> EI<sup>2</sup>OS service is usable if the other interrupt (s) which shares the ICR12 to ICRB and same interrupt vector is (are) not enabled.

### 20.2 Configuration of LIN-UART

### This section provides a short overview on the building blocks of LIN-UART.

LIN-UART consists of the following blocks:

- · Reload Counter
- Reception Control Circuit
- · Reception Shift Register
- Reception Data Register (RDR)
- Transmission Control Circuit
- Transmission Shift Register
- Transmission Data Register (TDR)
- Error Detection Circuit
- Oversampling circuit
- Interrupt Generation Circuit
- LIN Synch Break/Synch Field Detection Circuit
- LIN Synch Break Generation Circuit
- Bus Idle Detection Circuit
- LIN-UART Serial Mode Register (SMR)
- Serial Control Register (SCR)
- Serial Status Register (SSR)
- Extended Com. Contr. Reg. (ECCR)
- Extended Status/Contr. Reg. (ESCR)

### **■** Block Diagram of LIN-UART



Figure 20.2-1 Block Diagram of LIN-UART

n = 0, 1

### **■** Explanation of the different blocks

#### Reload Counter

The reload counter is a 15-bit reload counter that functions as the dedicated baud rate generator. It can select external clock or internal clock for the transmitting and receiving clocks. The reload counter has a 15-bit register for the reload value. The actual count of the transmission reload counter can be read via the BGRn0/n1.

#### Reception Control Circuit

The reception control circuit consists of a received bit counter, start bit detection circuit, and received parity counter. The received bit counter counts reception data bits. When reception of one data item for the specified data length is completed, the received bit counter sets the reception data register full flag. In this case, if the reception interrupt is enabled, the reception interrupt request is generated. The start bit detection circuit detects start bits from the serial input signal and sends a signal to the reload counter to synchronize it to the falling edge of these start bits. The received parity counter calculates the parity of the reception data.

#### Reception Shift Register

The reception shift register fetches reception data input from the SINn pin, shifting the data bit by bit. When reception is completed, the reception shift register transfers receive data to the RDR register.

### Reception Data Register (RDR)

This register retains reception data. Serial input data is converted and stored in this register.

#### Transmission Control Circuit

The transmission control circuit consists of a transmission bit counter, transmission start circuit, and transmission parity counter. The transmission bit counter counts transmission data bits. When the transmission of one data item of the specified data length is completed, the transmission bit counter sets the transmission data register full flag. In this case, if the transmission interrupt is enabled, the transmission interrupt request is generated. The transmission start circuit starts transmission when data is written to TDR register. The transmission parity counter generates a parity bit for data to be transmitted if parity is enabled.

### Transmission Shift Register

The transmission shift register transfers data written to the TDR register to itself and outputs the data to the SOTn pin, shifting the data bit by bit.

#### Transmission Data Register (TDR)

This register sets transmission data. Data written to this register is converted to serial data and outputted.

#### Error Detection Circuit

The error detection circuit checks if there was any error during the last reception. If an error has occurred it sets the corresponding error flags.

### Oversampling Circuit

The oversampling circuit oversamples the incoming data at the SINn pin for five times in the asynchronous mode. The received value is determined by majority decision of sampling time. It is switched off in synchronous operation mode.

#### Interrupt Generation Circuit

The interrupt generation circuit administers all cases of generating a reception or transmission interrupt. If a corresponding interrupt enable bit is set, the interrupt will be generated immediately.

### LIN synch Break and Synchronization Field Detection Circuit

The LIN break and LIN synchronization field detection circuit detects a LIN synch break if a LIN master node is sending a message header. If a LIN synch break is detected LBD flag bit is generated. The first and the fifth falling edge of the LIN synchronization field is recognized by this circuit by generating an internal signal for the Input Capture Unit to measure the actual serial clock synchronization of the transmitting master node.

### LIN Synch Break Generation Circuit

The LIN break generation circuit generates a LIN synch break of a determined length.

### Bus Idle Detection circuit

The bus idle detection circuit recognizes if neither reception nor transmission is going on. In this case, the circuit generates the special flag bits TBI and RBI.

#### LIN-UART Serial Mode Register (SMR)

This register performs the following operations:

- Selecting the LIN-UART operation mode
- Selecting a clock input source
- Selecting if an external clock is connected "one-to-one" or connected to the reload counter
- · Resetting dedicated reload timer
- Resetting the LIN-UART software (preserving the settings of the registers)
- Specifying whether to enable serial data output to the corresponding pin
- Specifying whether to enable clock output to the corresponding pin

### Serial Control Register (SCR)

This register performs the following operations:

- Specifying whether to provide parity bits
- Selecting parity bits
- · Specifying a stop bit length
- Specifying a data length
- Selecting a frame data format in mode 1
- Clearing the error flags
- Specifying whether to enable transmission
- Specifying whether to enable reception

### Serial Status Register (SSR)

This register performs the following functions;

- Indicating status of receive/transmit operations and errors
- Specifying LSB first or MSB first
- Receive interrupt enable/disable
- Transmit interrupt enable/disable

### Extended Communication Control Register (ECCR)

This register performs the following functions;

- Indicating bus idle detection
- Specifying synchronous clock
- Specifying LIN synch break generation

### Extended Status/Control Register (ESCR)

This register performs the following functions;

- LIN synch break interrupt enable/disable
- Indicating LIN synch break detection
- Specifying LIN synch break length
- Directly accessing SINn and SOTn pins
- Specifying continuous clock output operation in LIN-UART synchronous clock mode
- Specifying sampling clock edge

### 20.3 LIN-UART Pins

### This section describes the LIN-UART pins and provides a pin block diagram.

### **■ LIN-UART Pins**

The LIN-UART pins also serve as general ports. Table 20.3-1 lists the pin functions, I/O formats, and settings required to use LIN-UART.

Table 20.3-1 LIN-UART Pin

| Pin Name | Pin Function                          | I/O Format                            | Standby<br>Control | Setting Required to Use Pin                                                |
|----------|---------------------------------------|---------------------------------------|--------------------|----------------------------------------------------------------------------|
|          | Port I/O or serial data input         | CMOS output/CMOS,<br>Automotive input | Provided           | Set as input port (DDR: corresponding bit = 0)                             |
|          | Port I/O or serial<br>data output     |                                       |                    | Set to output enable mode (SMRn: SOE = 1)                                  |
|          | Port I/O or serial clock input/output |                                       |                    | Set as an input port when a clock is inputted (DDR: corresponding bit = 0) |
|          |                                       |                                       |                    | Set to output enable mode when a clock is outputted (SMRn: SCKE = 1)       |

See "3. DC Characteristics in ELECTRICAL CHARACTERISTICS" in the data sheet for the standard value.

### ■ Block Diagram of LIN-UART Pins

Figure 20.3-1 Block Diagram of LIN-UART Pins



### 20.4 LIN-UART Registers

The following figure shows the LIN-UART registers.

### **■ LIN-UART Registers**

Figure 20.4-1 LIN-UART Registers

| • LIN-UA              | RT0                 |                                          |                                                                |
|-----------------------|---------------------|------------------------------------------|----------------------------------------------------------------|
| Address:              |                     | bit 15 bit 8                             | bit 7 bit 0                                                    |
| $000021_{\rm H}$      | $000020_{\rm H}$    | SCR0 (serial control register)           | SMR0 (serial mode register)                                    |
| 000023 <sub>H</sub>   | 000022 <sub>H</sub> | SSR0 (serial status register)            | RDR0/TDR0 (reception data register/transmission data register) |
| 000025 <sub>H</sub>   | 000024 <sub>H</sub> | ESCR0 (Extended status control register) | ECCR0 (Extended communication control register)                |
| 000027 <sub>H</sub>   | 000026 <sub>H</sub> | BGR01 (Baud rate generator register)     | BGR00 (Baud rate generator register)                           |
|                       |                     |                                          |                                                                |
| • LIN-UA              | RT1                 |                                          |                                                                |
| Address:              |                     | bit 15 bit 8                             | bit 7 bit 0                                                    |
| 000029 <sub>H</sub>   | $000028_{\rm H}$    | SCR1 (serial control register)           | SMR1 (serial mode register)                                    |
| 00002B <sub>H</sub>   | $00002A_{\rm H}$    | SSR1 (serial status register)            | RDR1/TDR1 (reception data register/transmission data register) |
| $00002D_{\mathrm{H}}$ | 00002C <sub>H</sub> | ESCR1 (Extended status control register) | ECCR1 (Extended communication control register)                |
| 00002F <sub>H</sub>   | 00002E <sub>H</sub> | BGR11(Baud rate generator register)      | BGR10(Baud rate generator register)                            |
|                       |                     |                                          |                                                                |

### 20.4.1 Serial Control Register (SCR)

This register specifies parity bits, selects the stop bit and data lengths, selects a frame data format in mode 1, clears the reception error flag, and specifies whether to enable transmission and reception.

### ■ Serial Control Register (SCR)

Figure 20.4-2 Configuration of the Serial Control Register (SCR)



Table 20.4-1 Function of Each Bit in Serial Control Register (SCR)

| No.   | Bit Name                                     | Function                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15 | PEN:<br>Parity enable bit                    | This bit selects whether to add a parity bit during transmission or detect it during reception. Note:  Parity bit is only provided in mode 0 and in mode 2 if SSM of the ECCR is selected to 1.  This bit is fixed to 0 (no parity) in mode 3 (LIN).                                                                                                                                                       |
| bit14 | P:<br>Parity selection bit                   | When parity is provided, this bit selects even (0) or odd (1) parity                                                                                                                                                                                                                                                                                                                                       |
| bit13 | SBL:<br>Stop bit length<br>selection bit     | This bit selects the length of the stop bit of an asynchronous data frame or a synchronous frame if SSM of the ECCR is selected 1. This bit is fixed to 0 (1 stop bit) in mode 3 (LIN). Note:  At reception, first stop bit is always detected.                                                                                                                                                            |
| bit12 | CL:<br>Data length<br>selection bit          | This bit specifies the length of transmission or reception data. This bit is fixed to 1 (8 bits) in mode 2 and 3.                                                                                                                                                                                                                                                                                          |
| bit11 | AD:<br>Address/Data<br>format selection bit  | This bit specifies the frame data format to be transmitted and received in multiprocessor mode 1. Writing to this bit is provided for a master CPU, reading from it for slave CPU. A 1 indicates an address data frame, a 0 indicates a usual data frame.  The reading value is a value of last received data format.  Note: Please read the hints about using this bit in "20.8 Notes on Using LIN-UART". |
| bit10 | CRE:<br>Clear reception<br>error flag bit    | This bit clears the FRE, ORE, and PE flags of the Serial Status Register (SSR). Writing a 1 to it clears the error flag. Writing a 0 has no effect. Reading from it always returns 0. Note; Clear reception error flags after the receive operation.                                                                                                                                                       |
| bit9  | RXE:<br>Reception<br>operation enable bit    | This bit enables/disables LIN-UART reception. If this bit is set to 0, LIN-UART disables the reception of data frames. If this bit is set to 1, LIN-UART enables the reception of data frames. The LIN synch break detection in mode 3 remains unaffected. Note: If reception is disabled (RXE=0) during receiving, it is stopped immediately. In this case, data is not guaranteed.                       |
| bit8  | TXE:<br>Transmission<br>operation enable bit | This bit enables/disables LIN-UART transmission.  If the bit is set to 0, LIN-UART disables the transmission of data frames.  If the bit is set to 1, LIN-UART enables the transmission of data frames.  Note:  If transmission is disabled (TXE=0) during transmitting, it is stopped immediately.  In this case, data is not guaranteed.                                                                 |

### 20.4.2 LIN-UART Serial Mode Register (SMR)

This register selects an operation mode and baud rate clock and specifies whether to enable output of serial data and clocks to the corresponding pin.

### ■ LIN-UART Serial Mode Register (SMR)

Figure 20.4-3 Configuration of the Serial Mode Register (SMR)



Table 20.4-2 Function of Each Bit in Serial Mode Register (SMR)

| No.           | Bit name                                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------------|-----------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7,<br>bit6 | MD1, MD0:<br>Operation mode setting bits                        | These two bits set the LIN-UART operation mode.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| bit5          | OTO:<br>One-to-one external clock input<br>enable bit           | This bit sets an external clock directly to the LIN-UART serial clock by writing "1".  This function is used for operating mode 2 (synchronous) slave mode operation (ECCR:MS=1).  When EXT=0, this bit is fixed to "0".                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| bit4          | EXT:<br>External serial clock source<br>selection bit           | This bit selects the clock input.  When "0" is set to this bit, it selects the clock of internal baud rate generator (reload counter). When "1" is set to it, it selects the external serial clock source.                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| bit3          | REST:<br>Restart of dedicated reload<br>counter bit             | If a 1 is written to this bit, the reload counter is restarted. Writing 0 to it has no effect.  Reading from this bit always returns 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit2          | UPCL: LIN-UART programmable clear bit (LIN-UART software reset) | Writing a 1 to this bit resets LIN-UART immediately (LIN-UART software reset). The register settings are preserved. Possible reception or transmission will cut off. All flags (TDRE, RDRF, LBD, PE, ORE, FRE) are cleared. Reset the LIN-UART after disabling the interrupt and transmission. Also, when the reception data register is cleared (RDR = $00_{\rm H}$ ), the reload counter restarts. Writing 0 to this bit has no effect. Reading from it always returns 0.                                                                                                                                                                                            |
| bit1          | SCKE: LIN-UART serial clock output enable bit                   | This bit controls the serial clock I/O ports.  When this bit is 0, SCKn pin operates as general-purpose I/O port or serial clock input pin. When this bit is 1, the pin operates as serial clock output pin and outputs clock in operating mode 2 (synchronous).  Note:  When using SCKn pin as serial clock input (SCKE=0) pin, set the corresponding DDR bit of general-purpose port as input port. Also, select external clock (EXT = 1) using the external clock selection bit.  Reference:  When the SCKn pin is assigned to serial clock output (SCKE=1), it functions as the serial clock output pin regardless of the status of the general-purpose I/O ports. |
| bit0          | SOE:<br>LIN-UART serial data output<br>enable bit               | This bit enables or disables the output of serial data.  When this bit is 0, SOTn pin operates as general-purpose I/O port. When this bit is 1, SOTn pin operates as serial data output pins (SOTn).  Reference:  When the output of serial data is enabled (SOE=1), SOTn pin functions as serial data output pin (SOTn) regardless of the status of general-purpose I/O ports.                                                                                                                                                                                                                                                                                        |

### 20.4.3 Serial Status Register (SSR)

This register checks the transmission and reception status and error status, and enables and disables the transmission and reception interrupts.

### ■ Serial Status Register (SSR)

Figure 20.4-4 Configuration of the Serial Status Register (SSR)



Table 20.4-3 Function of Each Bit in Serial Status Register (SSR)

| No.   | Bit name                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15 | PE:<br>Parity error flag bit                         | <ul> <li>This bit is set to 1 when a parity error occurs during reception at PE=1 and is cleared when 1 is written to the CRE bit of the LIN-UART serial control register (SCR).</li> <li>A reception interrupt request is outputted when this bit and the RIE bit are 1.</li> <li>Data in the reception data register (RDR) is invalid when this flag is set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                            |
| bit14 | ORE:<br>Overrun error flag bit                       | <ul> <li>This bit is set to 1 when an overrun error occurs during reception and is cleared when 1 is written to the CRE bit of the LIN-UART serial control register (SCR).</li> <li>A reception interrupt request is outputted when this bit and the RIE bit are 1.</li> <li>Data in the reception data register (RDR) is invalid when this flag is set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit13 | FRE:<br>Framing error flag<br>bit                    | <ul> <li>This bit is set to 1 when a framing error occurs during reception and is cleared when 1 is written to the CRE bit of the LIN-UART serial control register (SCR).</li> <li>A reception interrupt request is outputted when this bit and the RIE bit are 1.</li> <li>Data in the reception data register (RDR) is invalid when this flag is set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                   |
| bit12 | RDRF:<br>Receive data full flag<br>bit               | <ul> <li>This flag indicates the status of the reception data register (RDR).</li> <li>This bit is set to 1 when reception data is loaded into RDR and can only be cleared to 0 when the reception data register (RDR) is read.</li> <li>A reception interrupt request is outputted when this bit and the RIE bit are 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit11 | TDRE:<br>Transmission data<br>empty flag bit         | <ul> <li>This flag indicates the status of the transmission data register (TDR).</li> <li>This bit is cleared to 0 when transmission data is written to TDR and indicates that valid data exists in TDR. This bit is set to 1 when data is loaded into the transmission shift register and transmission start and indicates that no valid data exists in TDR.</li> <li>A transmission interrupt request is generated if both this bit and the TIE bit are 1.</li> <li>If the LBR bit in the ECCR register is set to "1" while the TDRE bit is "1", then this bit once changes to "0". After the completion of LIN synch break generator, the TDRE bit changes back to "1".</li> <li>Note:</li> <li>This bit is set to 1 (TDR empty) as its initial value.</li> </ul> |
| bit10 | BDS:<br>Transfer direction<br>selection bit          | This bit selects whether to transfer serial data from the least significant bit (LSB first, BDS=0) or the most significant bit (MSB first, BDS=1).  Note:  The high-order and low-order sides of serial data are interchanged with each other during reading from or writing to the serial data register. If this bit is set to another value after the data is written to the RDR register, the data becomes invalid. This bit is fixed to "0" in mode 3 (LIN).                                                                                                                                                                                                                                                                                                     |
| bit9  | RIE:<br>Reception interrupt<br>request enable bit    | <ul> <li>This bit enables or disables the reception interrupt request output to the CPU.</li> <li>If any of the RDRF, PE, ORE and FRE bits is set to "1" and this bit is "1", then a reception interrupt request is outputted.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| bit8  | TIE:<br>Transmission request<br>interrupt enable bit | <ul> <li>This bit enables or disables the transmission interrupt request output to the CPU.</li> <li>A transmission interrupt request is outputted when this bit and the TDRE bit are 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

### 20.4.4 Reception and Transmission Data Register (RDR/TDR)

Both RDR and TDR registers are located at the same address. At reading, it functions as the reception data register. At writing, it functions as the transmission data register.

### ■ Reception Data Register (RDR)

Figure 20.4-5 Transmission and Reception Data Registers (RDR/TDR)



RDR is the data buffer register for serial data reception. The serial data signal transmitted to the SINn pin is converted in the shift register and stored in RDR register. When the data length is 7 bits, the uppermost bit (RDR: D7) contains 0. When the data is stored in this register and the reception data full flag bit (SSR: RDRF) is set to 1. If a reception interrupt request is enabled (SSR: RIE=1) at this point, a reception interrupt occurs.

Read RDR when the RDRF bit of the serial status register (SSR) is 1. The RDRF bit is cleared automatically to 0 when RDR is read. Also the reception interrupt is cleared if it is enabled and no error has occurred.

Data in RDR is invalid when a reception error occurs (SSR: PE, ORE, or FRE = 1).

### ■ Transmission Data Register (TDR)

TDR is the data buffer register for serial data transmission. When data to be transmitted is written to the transmission data register (TDR) in transmission enable state (SCR: TXE=1), it is transferred to the transmission shift register, then converted to serial data, and transmitted from the serial data output pin (SOTn pin). If the data length is 7 bits, the uppermost bit (TDR: D7) is invalid data.

When transmission data is written to this register, the transmission data empty flag bit (SSR: TDRE) is cleared to 0. When transfer to the transmission shift register is completed and transmission starts, the bit is set to 1. When the TDRE bit is 1, the next part of transmission data can be written. If transmission interrupt requests have been enabled, a transmission interrupt is generated. Write the next part of transmission data when a transmission interrupt is generated or the TDRE bit is 1.

#### Note:

TDR is a write-only register and RDR is a read-only register. These registers are located in the same address, so the read value is different from the write value. Therefore, instructions that perform a read-modify-write (RMW) operation, such as the INC/DEC instruction, cannot be used.

### 20.4.5 Extended Status/Control Register (ESCR)

This register provides several LIN functions, direct access to the SINn and SOTn pins and setting of continuous clock output and sampling clock edge in LIN-UART synchronous clock mode.

### **■** Extended Status/control Register (ESCR)

Figure 20.4-6 shows the Configuration of the extended status/control register (ESCR), and Table 20.4-4 shows the function of each bit.



401

Table 20.4-4 Function in Each Bit of the Extended Status/control Register (ESCR)

| NO.             | Bit name                                                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit15           | LBIE:<br>LIN synch break detection<br>interrupt enable bit | This bit enables/disables LIN synch break detection interrupt.  When the LBD bit is set to 1 and this bit is "1", a interrupt is generated. This bit is fixed to "0" in operation mode 1 and 2.                                                                                                                                                                                                                            |
| bit14           | LBD:<br>LIN synch break detected<br>flag bit               | This bit goes 1 if a LIN synch break was detected in operating mode 3.  Writing a 0 to it clears this bit and the corresponding interrupt, if it is enabled.  Read-modify-write instructions always return 1. Note that this dose not indicate a LIN synch break detection.  Note:  When LIN synch break detection is performed, disable reception (SCR: RXE=0) after enable LIN synch break detection interrupt (LBIE=1). |
| bit13,<br>bit12 | LBL1/0:<br>LIN synch break length<br>selection bits        | These two bits determine how many serial bit times the LIN synch break is generated by LIN-UART.  Receiving a LIN synch break is always fixed to 11 bit times.                                                                                                                                                                                                                                                             |
| bit11           | SOPE:<br>Serial Output pin direct<br>access enable bit *   | Setting this bit to 1 enables the direct write to the SOTn pin, if SOE = 1 (SMR). *                                                                                                                                                                                                                                                                                                                                        |
| bit10           | SIOP:<br>Serial Input/Output Pin<br>direct access bit *    | Normal read instructions always return the actual value of the SINn pin.  Writing to it sets the bit value to the SOTn pin, if SOPE = 1. During a Read- Modify-Write instruction the bit returns the SOTn value in the read cycle. *                                                                                                                                                                                       |
| bit9            | CCO:<br>Continuous Clock Output<br>enable bit              | This bit enables a continuous serial clock output at the SCKn pin if LIN-UART operates in master operation mode 2 (synchronous) and the SCKn pin is configured as a clock output. <note> When CCO bit is "1", use SSM bit of ECCR as setting to "1".</note>                                                                                                                                                                |
| bit8            | SCES:<br>Sampling clock edge<br>selection bit              | This bit inverts the serial clock signal in operation mode 2 (synchronous communication). Receiving data is sampled at the falling edge of the internal clock. If the MS bit of the ECCR register is "0" (master mode) and the SCKE bit of the SMR register is "1" (clock output enabled), the output clock signal is also inverted.  During operation mode 0,1,3, please set this bit to 0.                               |

<sup>\*:</sup> Refer to the following table.

Table 20.4-5 Description of the Interaction of SOPE and SIOP

| SOPE | SIOP | Writing to SIOP                                    | Reading from SIOP             |
|------|------|----------------------------------------------------|-------------------------------|
| 0    | R/W  | Has no effect on SOTn, but holds the written value | Returns current value of SINn |
| 1    | R/W  | Write "0" or "1" to SOTn                           | Returns current value of SINn |
| 1    | RMW  | Reads current value of SOTn and write it back      |                               |

### 20.4.6 Extended Communication Control Register (ECCR)

The extended communication control register (ECCR) provides bus idle detection, synchronous clock settings, and the LIN synch break generation.

### **■** Extended Communication Control Register (ECCR)

Figure 20.4-7 shows the configuration of the extended communication control register (ECCR), and Table 20.4-6 shows the function of each bit.



403

Table 20.4-6 Function of Each Bit in the Extended Communication Control Register (ECCR)

| NO.  | Bit name                                            | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7 | Unused bit                                          | This bit is unused bit. Reading bit is undefined. Always write "0".                                                                                                                                                                                                                                                                                                                                                                                                         |
| bit6 | LBR:<br>Lin Synch break Generating bit              | Writing a 1 to this bit generates a LIN synch break of the length selected by the LBL0/LBL1 bits of the ESCR, if operation mode 3 is selected. Setting to "0" in operation mode 0.                                                                                                                                                                                                                                                                                          |
| bit5 | MS:<br>Master/Slave mode selection bit in<br>mode 2 | This bit selects master or slave mode of LIN-UART in synchronous mode 2. If master is selected LIN-UART generates the synchronous clock by itself. If slave mode is selected, LIN-UART receives external serial clock.  This bit is fixed to "0" in operation mode 0, 1 and 3.  Change this bit, when the SCR: TXE bit is "0".  Note:  If slave mode is selected, the clock source must be external and enabled the external clock input (SMR: SCKE = 0, EXT = 1, OTO = 1). |
| bit4 | SCDE:<br>Serial clock delay enable bit in mode 2    | If this bit is set to 1 the serial output clock is delayed as shown in Figure 20.7-5 if LIN-UART operates in master mode 2. This bit is enabled to SPI.  This bit is fixed to "0" in operation mode 0, 1, and 3.                                                                                                                                                                                                                                                            |
| bit3 | SSM:<br>Start/Stop bit mode enable bit in mode<br>2 | This bit adds start and stop bits to the synchronous data format in operation mode 2. It is ignored in mode 0, 1, and 3. This bit is fixed to "0" in operation mode 0, 1, and 3.                                                                                                                                                                                                                                                                                            |
| bit2 | Unused bit                                          | Unused bit. Reading value is undefined. Always write to "0".                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit1 | RBI:<br>Reception bus idle detection flag bit       | This bit is "1" if there is no reception activity on the SINn pin and it is kept at "H".  Do not use this bit in mode 2 when SSM=0.                                                                                                                                                                                                                                                                                                                                         |
| bit0 | TBI:<br>Transmission bus idle detection flag bit    | This bit is "1" if there is no transmission activity on the SOTn pin. Do not use this bit in mode 2 when SSM=0.                                                                                                                                                                                                                                                                                                                                                             |

### 20.4.7 Baud Rate Generator Register 0 and 1 (BGR0/1)

The baud rate generator registers set the division ratio for the serial clock. Also, the actual count of the transmission reload counter can be read.

### ■ Baud Rate Generator Register (BGRn0/n1)

Figure 20.4-8 shows the configuration of the baud rate generator register (BGRn0/n1).



Figure 20.4-8 Configuration of Baud Rate Generator Register (BGRn0/n1)

The baud rate generator registers determine the division ratio for the serial clock.

The BGRn1 corresponds to the upper bit and BGRn0 to lower bit, writing of the reload value to counter and reading of the transmission reload counter value are allowed. Also, byte and word access are enabled. When writing the reload value to the baud rate generator register, the reload counter starts counting.

### 20.5 LIN-UART Interrupts

LIN-UART uses both reception and transmission interrupts. An interrupt request can be generated for either of the following causes:

- Receive data is set in the reception data register (RDR), or a reception error occurs.
- Transmission data is transferred from the transmission data register (TDR) to the transmission shift register and transmission is started.
- · A LIN break is detected.

The extended intelligent I/O service (El<sup>2</sup>OS) is available for these interrupts.

### **■ LIN-UART Interrupts**

Table 20.5-1 shows the interrupt control bits and interrupt cause of the LIN-UART.

Table 20.5-1 Interrupt Control Bits and Interrupt Cause of LIN-UART

| Reception/           | Interrupt           | Flag     | Operation mode |   |   | de | Interrupt cause                        | Interrupt           | How to clear the                                                                   |  |
|----------------------|---------------------|----------|----------------|---|---|----|----------------------------------------|---------------------|------------------------------------------------------------------------------------|--|
| transmission<br>/ICU | request<br>flag bit | register | 0              | 1 | 2 | 3  |                                        | cause enable<br>bit | interrupt request                                                                  |  |
| Reception            | RDRF                | SSR      | О              | О | О | О  | Receive data is written to RDR.        | SSR:RIE             | Receive data is read. "1" is written to clear reception error flag bit (SCR: CRE). |  |
|                      | ORE                 | SSR      | О              | О | О | О  | Overrun error                          |                     |                                                                                    |  |
|                      | FRE                 | SSR      | О              | О | Δ | О  | Framing error                          |                     |                                                                                    |  |
|                      | PE                  | SSR      | О              | × | Δ | ×  | Parity error                           |                     |                                                                                    |  |
|                      | LBD                 | ESCR     | ×              | × | × | О  | LIN Synch break detected               | ESCR:LBIE           | "0" is written to ESCR: LBD.                                                       |  |
| Transmission         | TDRE                | SSR      | О              | О | О | О  | TDR empty                              | SSR:TIE             | Write data to<br>TDR                                                               |  |
| Input Capture        | ICP0/ICP1           | ICS01    | ×              | × | × | О  | 1st falling edge of<br>LIN synch field | ICS01:<br>ICE0/ICE1 | Disable ICP0/<br>ICP1 temporary                                                    |  |
|                      | ICP0/ICP1           | ICS01    | ×              | × | × | О  | 5th falling edge of<br>LIN synch field |                     |                                                                                    |  |

O: Used bit

<sup>×:</sup> Unused bit

 $<sup>\</sup>Delta$ : Only available if ECCR/SSM = 1

#### Reception Interrupt

If one of the following events occurs in reception mode, the corresponding flag bit of the serial status register (SSR) is set to "1":

- Data reception is completed, i. e. the received data was transferred from the serial input shift register to the reception data register (RDR) and data can be read: RDRF
- Overrun error, i. e. RDRF = 1 and RDR was not read by the CPU and next serial data is received: ORE
- Framing error, i. e. a stop bit was expected, but a "0"-bit was received: FRE
- Parity error, i. e. a wrong parity bit was detected: PE

If at least one of these flag bits above go "1" and the reception interrupt is enabled (SSR: RIE = 1), a reception interrupt request is generated.

If the reception data register (RDR) is read, the RDRF flag is automatically cleared to "0". The error flags are cleared to "0", if a "1" is written to the clear reception error (CRE) flag bit of the serial control register (SCR).

#### Note:

The CRE flag is "write only" and by writing a "1" to it, it is internally held to "1" for one clock cycle.

#### Transmission Interrupt

If transmission data is transferred from the transmission data register (TDR) to the transfer shift register and transfer is started, the transmission data empty flag bit (TDRE) of the serial status register (SSR) is set to "1". In this case an interrupt request is generated, if the transmission interrupt enable (TIE) bit of the SSR was set to "1" before.

#### Note:

The initial value of TDRE (after hardware or software reset) is "1". So an interrupt is generated immediately then, if the TIE flag is set to "1". Also note, that the only way to reset the TDRE flag is writing data to the transmission data register (TDR).

#### LIN Synchronization Break Interrupt

This paragraph is only relevant, if LIN-UART operates in mode 3 as a LIN slave.

If the bus (serial input) goes "0" (dominant) for more than 11 bit times, the LIN synch break detected (LBD) flag bit of the extended status/control register (ESCR) is set to "1". Note, that in this case after 9 bit times the reception error flags are set to "1", therefore the RXE flag has to set to "0", if only a LIN synch break detect is desired.

The LIN synch break interrupt and the LBD flag are cleared after writing a "0" to the LBD flag. The LBD flag has to be performed before input capture interrupt for LIN synch field.

When LIN synch break detection is performed, it is necessary to disable the reception (SCR: RXE=0).

### LIN Synchronization Field Edge Detection Interrupts

This paragraph is only relevant, if LIN-UART operates in mode 3 as a LIN slave. After LIN synch break detection, the internal signal is set to "1" at first falling edge of the LIN synch field and to "0" after fifth falling edge. When the internal signal is set in the capture side to be inputted to capture (ICV0/1) and to be detected both edges, the interrupt occurs if the capture interrupt is enabled. The difference of the count values detected in the capture is serial clock 8 bits for master, and new baud rate can be calculated.

When the falling edge of the start bit is detected, the reload counter restarts automatically.

### ■ LIN-UART Interrupts and El<sup>2</sup>OS

Table 20.5-2 LIN-UART Interrupts and EI<sup>2</sup>OS

| Channel                | Interrupt<br>number   | Interrupt cor | ntrol register      | Ved                 | El <sup>2</sup> OS  |                     |    |
|------------------------|-----------------------|---------------|---------------------|---------------------|---------------------|---------------------|----|
|                        | Humber                | Register name | Address             | Lower               | Upper               | Bank                |    |
| LIN-UART0 reception    | #35(23 <sub>H</sub> ) | ICR12         | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub> | FFFF71 <sub>H</sub> | FFFF72 <sub>H</sub> | *1 |
| LIN-UART0 transmission | #36(24 <sub>H</sub> ) | ICR12         | 0000BC <sub>H</sub> | FFFF6C <sub>H</sub> | FFFF6D <sub>H</sub> | FFFF6E <sub>H</sub> | *2 |
| LIN-UART1 reception    | #37(25 <sub>H</sub> ) | ICR13         | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub> | FFFF69 <sub>H</sub> | FFFF6A <sub>H</sub> | *1 |
| LIN-UART1 transmission | #38(26 <sub>H</sub> ) | ICR13         | 0000BD <sub>H</sub> | FFFF64 <sub>H</sub> | FFFF65 <sub>H</sub> | FFFF66 <sub>H</sub> | *2 |

<sup>\*1:</sup> Usable when ICR12 and ICR13 or interrupt causes that share an interrupt vector are not used. Provided with a function that detects a LIN-UART reception error and stops EI<sup>2</sup>OS.

### ■ LIN-UART El<sup>2</sup>OS functions

LIN-UART has a circuit for operating EI<sup>2</sup>OS, which can be started up for either reception or transmission interrupts.

### For Reception

EI<sup>2</sup>OS can be used if other interrupt is not enabled because the UART shares the interrupt control registers with transmission interrupt and other UART.

#### For Transmission

LIN-UART shares the interrupt control registers with the LIN-UART reception interrupts and other UART. Therefore, EI<sup>2</sup>OS can be started up only when no LIN-UART reception interrupts are used.

<sup>\*2:</sup> Usable when ICR12 and ICR13 or interrupt causes that share an interrupt vector are not used.

### 20.5.1 Reception Interrupt Generation and Flag Set Timing

The following are the reception interrupt causes: completion of reception (SSR: RDRF) and occurrence of a reception error (SSR: PE, ORE, or FRE).

### ■ Reception Interrupt Generation and Flag Set Timing

The received data is stored in the RDR register if the first stop bit is detected in mode 0, 1, 2 (if SSM = 1), 3, or the last data bit was read in mode 2 (if SSM = 0).

Each flag is set if the received data is completed (RDRF = 1) and the reception error (PE, ORE, FRE) of the Serial Status Register (SSR) was set to "1". In this case, if the reception interrupt is enabled (SSR: RIE=1), reception interrupt occurs.

#### Note:

If a reception error has occurred, the Reception Data Register (RDR) contains invalid data in each mode.

Figure 20.5-1 Reception Operation and Flag Set Timing Receive data (mode 0/3) ST D0 D1 D2 D5 D6 D7/P/ SP ST Receive data (mode 1) D0 D1 D2 D7 A/D D6 Receive data (mode 2) D0 D1 D2 D4 D5 D6 D7 D0 PE\*1, FRE **RDRF** ORE\*2 (RDRF = "1")Reception interrupt occurs

Figure 20.5-1 shows the reception operation and flag set timing.

- \*1: The PE flag will always remain "0" in mode 1 or 3.
- \*2: ORE only occurs, if next data is transferred before the reception data is read (RDRF=1).
- ST: Start Bit SP: Stop Bit A/D: Mode 1 (multiprocessor) address/data selection bit

#### Note:

The example in Figure 20.5-1 does not show all possible reception options for mode 0. Here it is: "7p1" and "8N1" (p = "E" [even] or "O" [odd]).

### Figure 20.5-2 ORE Flag Set Timing:



### 20.5.2 Transmission Interrupt Generation and Flag Set Timing

A transmission interrupt is generated when the transmission data is transferred from transmission data register (TDR) to transmission shift register and transmission is started.

### ■ Transmission Interrupt Generation and Flag Set Timing

When the data written to the TDR register is transferred to the transmission shift register and the transmission is started, next data to be written is enabled (SSR: TDRE=1). Then, if transmission interrupt is enabled (SSR: TIE=1), the transmission interrupt occurs. Because the TDRE bit is "read only", it only can be cleared to "0" by writing data into TDR.

The following figure demonstrates the transmission operation and flag set timing for the four modes of LIN-UART.



Figure 20.5-3 Transmission Operation and Flag Set Timing

#### Note:

The example in Figure 20.5-3 does not show all possible transmission options for mode 0. Here it is: "8p1" (p = "E" [even] or "O" [odd]). Parity is not provided in mode 3 or 2, if SSM = 0.

### **■** Transmission interrupt request generation timing

If the TDRE flag is set to "1" when a transmission interrupt is enabled (SSR: TIE=1), transmission interrupt is generated.

#### Note:

A transmission interrupt is generated immediately after the transmission interrupt is enabled (SSR: TIE=1) because the TDRE bit is set to 1 as its initial value. TDRE is a read-only bit that can be cleared only by writing new data to the transmission data register (TDR). Carefully specify the transmission interrupt enable timing.

### 20.6 LIN-UART Baud Rates

## One of the following can be selected for the LIN-UART transmission/reception clock source:

- Dedicated baud rate generator (Reload Counter)
- Input external clock to baud rate generator (Reload Counter)
- External clock (directly use SCKn pin input clock)

#### ■ LIN-UART Baud Rate Selection

The baud rate selection circuit is designed as shown below. One of the following three types of baud rates can be selected:

Baud rates determined using the dedicated baud rate generator (reload counter) with internal clock

LIN-UART has two independent internal reload counters for transmission and reception serial clock. The baud rate can be selected via the 15-bit reload value determined by the Baud Rate Generator Register 0 and 1 (BGR0/1).

The reload counter divides the internal clock by set value.

It is used in asynchronous or synchronous (master) mode. Internal clock and baud rate generator clock is selected for the setting of clock source (SMR: EXT=0, OTO=0).

Baud rates determined using the dedicated baud rate generator (reload counter) with external clock

An external clock source can also be connected internally to the reload counter. The baud rate can be selected via the 15-bit reload value determined by the baud rate generator register 0 and 1 (BGR 0/1). The reload counter divides the external clock by set value. It is used in asynchronous mode. External clock and baud rate generator clock is selected for the setting of the clock source (SMR: EXT=1, OTO=0). This was designed to use quartz oscillators with special frequencies and having the possibility to divide them.

Baud rates determined using external clock (one-to-one mode)

The clock input from LIN-UART clock pulse input pins (SCKn) is used as it is (synchronous mode 2 slave operation (ECCR: MS=1)). It is used in synchronous mode (slave). External clock and direct use of external clock is selected for the setting of clock source (SMR: EXT=1, OTO=1).



Figure 20.6-1 Baud Rate Selection Circuit of LIN-UART

### 20.6.1 Setting the Baud Rate

This section describes how the baud rates are set and the resulting serial clock frequency is calculated.

### **■** Calculating the Baud Rate

The both 15-bit reload counters are programmed by the baud rate generator registers 1, 0 (BGR1/BGR0). The following calculation formula should be used to set the desired baud rate:

Reload Value:

$$v = [\Phi / b] - 1$$
,

where  $\Phi$  is the machine clock, b the baud rate and [] gaussian brackets (mathematical rounding function).

### Example of calculation

If the machine clock is 16 MHz and the desired baud rate is 19200 bps baud then the reload value v is:

$$v = [16*10^6 / 19200] - 1 = 832$$

The exact baud rate can then be recalculated:  $b_{exact} = \Phi / (v + 1)$ , here it is:  $16*10^6 / 833 = 19207.6831$ 

#### Note:

Setting the reload value to 0 stops the reload counter. For this reason the minimum division ratio is 2. For asynchronous communication, the reload value must be greater than equal to 4 because 5 times over-sampling is performed to determine the reception value internally.

### ■ Suggested division ratios for different machine speeds and baud rates

The following settings are suggested for different MCU clock speeds and baud rates:

Table 20.6-1 Suggested Baud Rates and Reload Values at Different Machine Speeds.

| Baud<br>rate | 8 MHz |        | 10 MHz |       | 16 1  | MHz    | 20 MHz |        | 24 MHz |        |
|--------------|-------|--------|--------|-------|-------|--------|--------|--------|--------|--------|
|              | value | dev.   | value  | dev.  | value | dev.   | value  | dev.   | value  | dev.   |
| 4M           | -     | -      | -      | -     | -     | -      | 4      | 0      | 5      | 0      |
| 2M           | -     | -      | 4      | 0     | 7     | 0      | 9      | 0      | 11     | 0      |
| 1M           | 7     | 0      | 9      | 0     | 15    | 0      | 19     | 0      | 23     | 0      |
| 500000       | 15    | 0      | 19     | 0     | 31    | 0      | 39     | 0      | 47     | 0      |
| 460800       | -     | -      | -      | -     | -     | -      | -      | -      | 51     | -0.16  |
| 250000       | 31    | 0      | 39     | 0     | 63    | 0      | 79     | 0      | 95     | 0      |
| 230400       | -     | -      | -      | -     | -     | -      | -      | -      | 103    | -0.16  |
| 153600       | 51    | -0.16  | 64     | -0.16 | 103   | -0.16  | 129    | -0.16  | 155    | -0.16  |
| 125000       | 63    | 0      | 79     | 0     | 127   | 0      | 159    | 0      | 191    | 0      |
| 115200       | 68    | -0.64  | 86     | 0.22  | 138   | 0.08   | 173    | 0.22   | 207    | -0.16  |
| 76800        | 103   | -0.16  | 129    | -0.16 | 207   | -0.16  | 259    | -0.16  | 311    | -0.16  |
| 57600        | 138   | 0.08   | 173    | 0.22  | 277   | 0.08   | 346    | -0.06  | 416    | 0.08   |
| 38400        | 207   | -0.16  | 259    | -0.16 | 416   | 0.08   | 520    | 0.03   | 624    | 0      |
| 28800        | 277   | 0.08   | 346    | <0.01 | 554   | -0.01  | 693    | -0.06  | 832    | -0.03  |
| 19200        | 416   | 0.08   | 520    | 0.03  | 832   | -0.03  | 1041   | 0.03   | 1249   | 0      |
| 10417        | 767   | < 0.01 | 959    | <0.01 | 1535  | <0.01  | 1919   | <0.01  | 2303   | < 0.01 |
| 9600         | 832   | 0.04   | 1041   | 0.03  | 1666  | 0.02   | 2083   | 0.03   | 2499   | 0      |
| 7200         | 1110  | < 0.01 | 1388   | <0.01 | 2221  | < 0.01 | 2777   | <0.01  | 3332   | < 0.01 |
| 4800         | 1666  | 0.02   | 2082   | -0.02 | 3332  | < 0.01 | 4166   | < 0.01 | 4999   | 0      |
| 2400         | 3332  | <0.01  | 4166   | <0.01 | 6666  | <0.01  | 8332   | <0.01  | 9999   | 0      |
| 1200         | 6666  | <0.01  | 8334   | 0.02  | 13332 | <0.01  | 16666  | <0.01  | 19999  | 0      |
| 600          | 13332 | <0.01  | 16666  | <0.01 | 26666 | <0.01  | -      | -      | -      | -      |
| 300          | 26666 | <0.01  | -      | -     | -     | -      | -      | -      | -      | -      |

### Note:

Deviations are given in%.

Maximum Synchronous Baud Rate: MCU-Clock div. by 5.

#### **■** Using external clock

If the EXT bit of the SMR is set to 1, an external clock is selected, which has to be connected to the SCKn pin. The external clock is used in the same way as the internal clock to the baud rate generator.

If One-to-one External Clock Input Mode (SMR: OTO=1) is selected the SCKn signal is directly connected to the LIN-UART serial clock inputs. This is needed for the LIN-UART synchronous mode 2 operating as slave device.

#### Note:

In any case the resulting clock signal is synchronized to the internal clock in the LIN-UART module. This means that indivisible clock rates will result in phase unstable signals.

#### **■** Counting Example

Assume the reload value is 832. Figure 20.6-2 demonstrates the behavior of both Reload Counters:

Transmission/Reception Clock Reload 832 829 001 000 831 830 828 827 Counter Reload counter value Transmission/Reception Clock Reload 417 416 415 414 413 412 411 410 Counter

Figure 20.6-2 Counting Example of the Reload Counters

#### Note:

The falling edge of the Serial Clock Signal always occurs after |(v + 1)/2|.

# 20.6.2 Restarting the Reload Counter

The reload counter is a 15-bit reload counter that functions as dedicated baud rate generator. The transmission/reception clock is generated by the external or internal clock. Also, the count value of the transmission reload counter can be read by the baud rate generator register (BGR1, BGR0).

#### ■ Function of Reload Counter

The reload counter has the transmission and reception reload counters and functions as dedicated baud rate generator. It consists of a 15-bit register for the reload value and generates the transmission/reception clocks by the external or internal clock. Also, the count value of the transmission reload counter can be read by the baud rate generator register (BGR1, BGR0)

#### Count start

When the reload value is written to the baud rate generator register (BGR1, BGR0), the reload counter starts counting.

#### Restart

If the REST bit of the Serial Mode Register (SMR) is set to "1", both Reload Counters are restarted at the next clock cycle. This feature is intended to use the Transmission Reload Counter as a simple timer.

The following figure illustrates a possible usage of this feature (assume that the reload value is 100.)



In this example the number of MCU clock cycles (cyc) after REST is then:

$$cyc = v - c + 1 = 100 - 90 + 1 = 11,$$

where v is the reload value and c is the read counter value.

#### Note:

If LIN-UART is reset by setting SMR:UPCL to "1", the Reload Counters will restart too.

 Automatic restart (reception reload counter only)
 In asynchronous LIN-UART mode, if a falling edge of a start bit is detected, the Reception Reload Counter is restarted. This is intended to synchronize the serial shift register to the incoming serial data stream.

#### Clearing reload counters

The reload value of the baud rate generator register (BGR1, BGR0) and the reload counters are cleared to "00" by the MCU global reset and the counters stops. The reload counters are cleared to "00 $_{\rm H}$ " by writing "1" to the UPCL bit in the SMR register. However, the value stored in the reload register is kept unchanged and the counters restart from reload value immediately. Writing "1" to the REST bit does not clear the counters and they restart from reload value immediately.

## 20.7 Operation of LIN-UART

LIN-UART operates in operation mode 0 for normal bidirectional serial communication, in mode 2 and 3 in bidirectional communication as master or slave, and in mode 1 as master or slave in multiprocessor communication.

#### ■ Operation of LIN-UART

#### Operation modes

There are four LIN-UART operation modes: modes 0 to 3. As listed in Table 20.7-1, an operation mode can be selected according to the communication method.

Table 20.7-1 Operation Mode of LIN-UART

| Operation mode |                        | Data I           | length         | Synchronization Length of stop bit of mode | Length of stop bit | Data bit format |
|----------------|------------------------|------------------|----------------|--------------------------------------------|--------------------|-----------------|
|                |                        | Parity disabled  | Parity enabled | ormode                                     |                    | IOITIIat        |
| 0              | Normal mode            | 7 or 8 bits      |                | Asynchronous                               | 1 or 2 bits        | LSB first       |
| 1              | Multiprocessor<br>mode | 7 or 8 bits + 1* | -              | Asynchronous                               |                    | MSB first       |
| 2              | Normal mode            | 8                |                | Synchronous                                | None, 1 or 2 bits  |                 |
| 3              | LIN mode               | 8                | -              | Asynchronous                               | 1 bit              | LSB first       |

<sup>-:</sup> Setting disabled

#### Note:

Mode 1 operation is supported both for master or slave operation of LIN-UART in a master-slave connection system. In Mode 3, the LIN-UART function is locked to 8N1-Format, LSB first.

If the mode is changed, LIN-UART cuts off all possible transmission or reception and awaits then new action.

<sup>\*: &</sup>quot;+1" means the indicator bit of the address/data selection used for controlling communication in the multiprocessor mode.

#### ■ Inter-CPU Connection Method

External Clock One-to-one connection (normal mode) and master-slave connection (multiprocessor mode) can be selected. For either connection method, the data length, whether to enable parity, and the synchronization method must be common to all CPUs. Select an operation mode as follows:

- In the one-to-one connection method, operation mode 0 or 2 must be used in the two CPUs. Select operation mode 0 for asynchronous transfer mode and operation mode 2 for synchronous transfer mode. Note, that one CPU has to set to the master and the other to the slave in synchronous mode 2.
- Select operation mode 1 for the master-slave connection method and use it either for the master or slave system.

#### ■ Synchronization Methods

In asynchronous operation, LIN-UART reception clock is automatically synchronized to the falling edge of a received start bit.

In synchronous mode, the synchronization is performed either by the clock signal of the master device or by LIN-UART itself if operating as master.

#### ■ Signal Mode

LIN-UART can treat data only in non-return to zero (NRZ) format.

#### **■** Operation Enable Bit

LIN-UART controls both transmission and reception using the operation enable bit for transmission (SCR: TXE) and reception (SCR: RXE).

- If reception operation is disabled during reception (data is input to the reception shift register), finish frame reception and read the received data of the reception data register (RDR). Then stop the reception operation.
- If the transmission operation is disabled during transmission (data is output from the transmission shift register), wait until there is no data in the transmission data register (TDR) before stopping the transmission operation.

# 20.7.1 Operation in Asynchronous Mode (Op. Modes 0 and 1)

When LIN-UART is used in operation mode 0 (normal mode) or operation mode 1 (multiprocessor mode), the asynchronous transfer mode is selected.

#### ■ Operation in Asynchronous Mode

#### Transfer data format

Generally each data transfer in the asynchronous mode operation begins with the start bit (low-level) and ends with at least one stop bit (high-level). The direction of the bit stream (LSB first or MSB first) is determined by the BDS bit of the Serial Status Register (SSR). The parity bit (if enabled) is always placed between the last data bit and the (first) stop bit.

In operation mode 0 the length of the data frame can be 7 or 8 bits, with or without parity, and 1 or 2 stop bits.

In operation mode 1 the length of the data frame can be 7 or 8 bits with a following address-/data-selection bit instead of a parity bit. 1 or 2 stop bits can be selected.

The calculation formula for the bit length of a transfer frame is:

```
Length = 1 + d + p + s
```

(d = number of data bits [7 or 8], p = parity [0 or 1], s = number of stop bits [1 or 2]

Figure 20.7-1 shows the data format in the asynchronous mode.



Figure 20.7-1 Transfer Data Format (operation Modes 0 and 1)

#### Note:

If BDS bit of the Serial Status Register (SSR) is set to "1" (MSB first), the bit stream processes as: D7, D6, ..., D1, D0, (P).

#### Transmission operation

If the Transmission Data Register Empty (TDRE) flag bit of the Serial Status Register (SSR) is "1", transmission data is allowed to be written to the Transmission Data Register (TDR). When data is written, the TDRE flag goes "0". If the transmission operation is enabled by the TXE-Bit ("1") of the Serial Control Register (SCR), the data is written next to the transmission shift register and the transmission starts at the next clock cycle of the serial clock, beginning with the start bit.

If transmission interrupt is enabled (TIE = 1), the interrupt is generated by the TDRE flag. Note, that the initial value of the TDRE flag is "1", so that in this case if TIE is set to "1" an interrupt will occur immediately.

When the data length is set to 7 bits (CL=0), the unused bit of the TDR is always the MSB, independently from the transfer direction selection in the BDS bit (LSB first or MSB first).

#### Note:

As the initial value of transmission data empty flag bit (SSR: TDRE) is "1" if the transmission interrupt is enabled (SSR: TIE=1), the interrupt occurs immediately.

#### Reception operation

Reception operation is performed when it is enabled by the Reception Enable (RXE) flag bit of the SCR. If a start bit is detected, a data frame is received according to the data format specified by the SCR. In case of errors, the corresponding error flags are set (SSR: PE, ORE, FRE). After the reception of the data frame, the data is transferred from the reception shift register to the Reception Data Register (RDR) and the Receive Data Register Full (RDRF) flag bit of the SSR is set to "1". In this case, if the reception interrupt request is enabled (SSR: RIE=1), the reception interrupt request is occurred. When reading data after reception of one frame data, check the error flag state and read reception data from the RDR register if the reception is performed normally. If the reception error occurs, perform error processing. The data then has to be read by the CPU. By doing so, the RDRF flag of SSR is cleared to "0".

When the data length is set to 7 bits (CL=0), the unused bit of the TDR is always the MSB, independently from the bit transfer direction selection in the BDS bit (LSB first or MSB first).

#### Note:

Only when the RDRF flag bit of SSR is set to "1" and no errors have occurred (SSR: PE, ORE, FRE=0) the Reception Data Register (RDR) contains valid data.

#### Used clock

Use the internal clock or external clock. Select the baud rate generator (SMR: EXT = 0 or 1, OTO = 0) for desired baud rate.

#### Stop bit

1- or 2-stop bit can be selected at the transmission. When 2-stop bit is selected, both stop bits is detected at the reception. When first stop bit is detected, the RDRF bit of SSR is "1". Then, when the start bit is not detected, the RBI bit of ECCR is set to "1", indicating no reception operation.

#### Error detection

In mode 0, the parity, overrun, and framing errors can be detected.

In mode 1, the overrun and framing errors can be detected, and the parity error cannot be detected.

#### Parity

Parity can set to add (transmission) or detect (reception) the parity bit.

The parity enable bit (SCR: PEN) is used to specify whether there is parity or not, and parity selection bit (SCR: P) is selected the even/odd parity.

In operation mode 1, the parity cannot be used.



Figure 20.7-2 Transmission Data when Parity Enabled

#### Data signal type

The data signal type is NRZ data format.

#### Data transition method

The data bit transfer method can be selected by LSB or MSB first.

# 20.7.2 Operation in Synchronous Mode (Operation Mode 2)

The clock synchronous transfer method is used for LIN-UART operation mode 2 (normal mode).

#### ■ Operation in Synchronous Mode (Operation mode 2)

#### Transfer data format

In the synchronous mode, 8-bit data is transferred without start or stop bits if the SSM bit of the Extended Communication Control Register (ECCR) is 0. Also, when the start/stop bit is provided (ECCR: SSM = 1), presence or absence of the parity bit can be selected (SCR: PEN). The figure below illustrates the data format during a transmission in the synchronous operation mode.

Figure 20.7-3 Transfer Data Format (operation mode 2)



#### Clock inversion function

If the SCES bit of the Extended Status/Control Register (ESCR) is set to "1", the serial clock is inverted. Therefore, in slave mode LIN-UART samples the data bits at the falling edge of the received serial clock. Note, that in master mode if SCES is set to "1", the clock signal's mark level is "0".

Figure 20.7-4 Transfer Data Format with Clock Inversion



#### Start/stop bits

If the SSM bit of the Extended Communication Control Register (ECCR) is set to "1", the data format gets additional start and stop bits like in asynchronous mode.

#### Clock supply:

In operation mode 2, the number of clock cycles for the clock signal must be the same as the number of bits for the transmission and reception. If the start/stop bits are enabled, it must be matched the additional start/stop bits. If the MS bit of the ECCR register is "0" (master mode) and the SCKE bit of the SMR register is "1" (serial clock output enabled), the consistent clock cycles are generated automatically. If the MS bit of the ECCR register is "1" (slave mode), or if the SCKE bit of SMR is 0 (serial clock output disabled), the clock for each bit of transfer data must be supplied from outside. While there is no communication, the clock signal must be kept at "H" as the mark level

If the SCDE bit of the ECCR register is "1", the clock output signal is delayed by the half of the serial clock cycle as shown in Figure 20.7-5. The operation is prepared for communication devices which use the rising or falling edge of the serial clock signal for the data sampling.



Figure 20.7-5 Delayed Transmitting Clock Signal(SCDE=1)

If the SCES bit of the ESCR register is "1", the serial clock signal is inverted. Receiving data is sampled at the falling edge of the serial clock.

In this case, the serial data must be valid value at the falling edge of the clock. If the CCO bit of ESCR register is "1" (master mode), the serial clock output of the SCKn pin is supplied continuously. In this mode, be sure to add the start/stop bits (SSM = 1) to identify the start and end of data frame. Figure 20.7-6 shows the operation of this function.



Figure 20.7-6 Continuous Clock Supply in Mode 2

#### Error detection:

If no start/stop bits are selected (ECCR: SSM = 0) only overrun errors are detected.

#### Communication:

For initialization of the synchronous mode, following settings have to be done:

#### Baud rate generator registers (BGR0/BGR1):

Set the desired reload value for the dedicated baud rate reload counter.

#### Serial mode register (SMR):

```
MD1, MD0: "10<sub>B</sub>" (Mode 2)
```

SCKE: "1" for the dedicated baud rate reload counter

"0" for external clock input

SOE: "1" for transmission and reception

"0" for reception only

#### **Serial control register (SCR):**

RXE, TXE: set one or both of these bits to "1"

AD: no address/data selection - don't care

CL: automatically fixed to 8-bit data - don't care

CRE: "1" to clear receive error flags. Suspend transmission and reception.

#### -- when SSM=0:

PEN, P, SBL: don't care

#### -- when SSM=1:

PEN: "1" if parity bit is added/detected, "0" if not

P: "0" for even parity, "1" odd parity

SBL: "1" for 2 stop bits, "0" for 1 stop bit.

#### **Serial status register (SSR):**

BDS: "0" for LSB first, "1" for MSB first

RIE: "1" if reception interrupts are used; "0" reception interrupts are disabled.

TIE: "1" if transmission interrupts are used; "0" transmission interrupts are disabled.

#### **Extended communication control register (ECCR):**

SSM: "0" if no start/stop bits are desired (normal); "1" for adding start/stop bits (extended function)

MS: "0" for master mode (LIN-UART generates the serial clock); "1" for slave mode (LIN-UART receives serial clock from the master device)

#### Note:

To start the communication, write data to TDR register. When receiving the data, disable the serial output (SMR: SOE = "0") and write the dummy data to TDR. By enabling the continuous clock and start/stop bits, in the bi-directional communication the same as the asynchronous mode is allowed.

# 20.7.3 Operation with LIN Function (Operation Mode 3)

LIN-UART can be used either as LIN-Master or LIN-Slave. For this LIN function a special mode is provided. Setting the LIN-UART to mode 3 configures the data format to 8N1-LSB-first format.

#### ■ Operation in Asynchronous LIN Mode (Operation mode 3)

#### LIN-UART as LIN master

In LIN master mode, the master determines the baud rate of the whole bus, therefore slaves devices have to synchronize to the master. Therefore, the desired baud rate remains fixed in master operation after initialization.

Writing a "1" into the LBR bit of the Extended Communication Control Register (ECCR) generates a 13-16 bit time low-level on the SOTn pin, which is the LIN synchronization break and the start of a LIN message. Thereby the TDRE flag of the Serial Status Register (SSR) goes "0" and is reset to "1" after the break, and generates a transmission interrupt for the CPU (if TIE of SSR is "1").

The length of the LIN break to be sent can be determined by the LBL1/0 bits of the ESCR as follows:

| LBL0 | LBL1 | Break length |
|------|------|--------------|
| 0    | 0    | 13 bits      |
| 1    | 0    | 14 bits      |
| 0    | 1    | 15 bits      |
| 1    | 1    | 16 bits      |

Table 20.7-2 LIN Break Length

The Synch Field is sent as byte data of 0x55 after the LIN break. To prevent a transmission interrupt, the 0x55 can be written to the TDR just after writing the "1" to the LBR bit, although the TDRE flag is "0".

#### LIN-UART as LIN slave

In LIN slave mode, LIN-UART has to synchronize to the master's baud rate. If Reception is disabled (RXE = 0) but LIN break interrupt is enabled (LBIE = 1) LIN-UART will generate a reception interrupt, if a synchronization break from the LIN master is detected, and indicates it with the LBD flag of the ESCR to "1". Writing "0" to this bit clears the reception interrupt request. For the calculation of the baud rate, the UARTO operation is explained as an example. When UARTO detects first falling edge of synch field, set the internal signal inputted to the input capture (ICU0) to "H" and start ICU0. This internal signal is set to "L" at fifth falling edge, ICU0 must be set to the LIN mode (ICE01). Also, the ICUO interrupt must be set to enable and to detect both edges (ICS01).

The time when the ICU0 input signal is "1" is the value in which eight baud rates are multiplied. Therefore, baud rate setting value is summarized as follows:

without free-run timer overflow : BGR value = (b-a)/8 - 1 with free-run timer overflow : BGR value = (Max + b-a)/8 - 1

where Max is the free-run timer maximum value at the overflow occurs.

where a is the value of the ICU data register after the first interrupt where b is the value of the ICU data register after the second interrupt

#### Note:

As shown in the LIN slave mode, when the BGR value newly calculated by synch field generates  $\pm 15\%$  or more baud rate error, do not set the baud rate.

For the correspondence between other LIN-UARTs and ICUs, see "13.5 Explanation of Operation of 16-bit Free-run Timer" and "13.6 Explanation of Operation of Input Capture".

#### LIN Synch Break Detection Interrupt and Flags

If a LIN Synch break is detected in the slave mode, the LIN Break Detected (LBD) Flag of the ESCR is set to "1". This causes an interrupt, if the LIN Break Interrupt Enable (LBIE) bit is set to 1.



Figure 20.7-7 LIN Synch Break Detection and Flag Set Timing.

The figure above demonstrates the LIN synch break detection and flag set timing.

Note, that if reception is enabled (RXE = 1) and reception interrupt is enabled (RIE = 1) the Reception Data Framing Error (FRE) flag bit of the SSR will cause a reception interrupt 2 bit times ("8N1") earlier than the LIN break interrupt, so it is recommended to turn off RXE, if a LIN break is expected.

LIN synch break detection is only supported in operation mode 3.

Figure 20.7-8 shows a typical start of a LIN message and the behavior of the LIN-UART.

Serial clock Serial input (LIN bus) LBR cleared by CPU LBD ICU input Synch break (at 14-bit setting) signal Synch field (LSYN)

Figure 20.7-8 LIN-UART Behavior as Slave in LIN Mode

LIN bus timing



Figure 20.7-9 LIN Bus Timing and LIN-UART Signals

#### 20.7.4 Direct Access to Serial Pins

LIN-UART allows the user to directly access to the transmission pin (SOTn) or the reception pin (SINn).

#### **■ LIN-UART Direct Pin Access**

The LIN-UART provides the ability for the software to access directly to serial input or output pin. The software can always monitor the incoming serial input pin (SINn) by reading the SIOP bit of the ESCR. If direct write to the serial output pin (SOTn) is allowed (ESCR: SOPE = 1) when the serial output is enabled (SMR: SOE = 1) after "0" or "1" is written to the SIOP bit of the ESCR register, the SOTn value can be set arbitrarily.

In LIN mode, this function can be used for reading back the own transmission and is used for error handling if something is physically wrong with the single-wire LIN-bus.

#### **Notes:**

- Direct access is enabled only when the transmission is not ongoing (transmission shift register is empty).
- Write a value to the SIOP bit of ESCR register before enabling the transmission (SMR: SOE = 1). This prevents the signal of the unexpected level from being outputted because the SIOP bit retains the previous value.
- During a Read-Modify-Write instruction the SIOP bit returns the actual value of the SOTn pin in the read cycle instead of the value of SINn during a normal read instruction.

#### **Bidirectional Communication Function (Normal Mode)** 20.7.5

In operation mode 0 or 2, normal serial bidirectional communication is available. Select operation mode 0 for asynchronous communication and operation mode 2 for synchronous communication.

#### ■ Bidirectional Communication Function

The settings shown in Figure 20.7-10 are required to operate LIN-UART in normal mode (operation mode

bit 15 bit 14 bit 13 bit 12 bit 11 bit 10 bit 9 bit 8 bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0 SCRn, SMRn PEN SBL CL AD | CRE|RXE|TXE|MD1|MD0|OTO|EXT|REST|UPCL|SCKE|SOE Mode 0 0 0 0 Mode 2 -Ŏ Ŏ Õ Χ 0 0 0 0 0 0 0 SSRn, TDRn/RDRn Set conversion data (during writing) PΕ ORE FRE RDRFTDRE BDS RIE TIE Retain reception data (during reading) Mode 0 0 0 Mode 2 -Õ 0 0 0 0 0 ESCRn, ECCRn LBIE LBD LBL1 LBL0 SOPE SIOP CCO SCES LBR MS SCDE SSM RBI TBI Mode 0 0 0 Mode 2 0 0 0 ©: Used bit x: Unused bit 1: Set 1 0: Set 0 □: Bit used if SSM = 1 (Synchronous start-/stop-bit mode) n = 0, 1+: Bit automatically set to correct value

Figure 20.7-10 Settings for LIN-UART Operation Mode 0 and 2

#### Inter-CPU connection

As shown in Figure 20.7-11, interconnect two CPUs in LIN-UART mode 2

SOT SOT SIN SIN Output Input SCK SCK CPU-1 (Master) CPU-2 (Slave)

Figure 20.7-11 Connection Example of LIN-UART Mode 2 Bidirectional Communication

#### Communication procedure

Communication starts at arbitrary timing from the transmission side when the transmission data is provided. When the transmission data is received at the reception side, ANS (per one byte in example) is returned periodically. Figure 20.7-12 shows an example of the bi-directional communication flowchart.



Figure 20.7-12 Example of Master-slave Communication Flowchart

#### **Master-Slave Communication Function (Multiprocessor** 20.7.6 Mode)

LIN-UART communication with multiple CPUs connected in master-slave mode is available for both master or slave systems in the operation mode 1.

#### ■ Master-slave Communication Function

The settings shown in Figure 20.7-13 are required to operate LIN-UART in multiprocessor mode (operation mode 1).

bit 15 bit 14 bit 13 bit 12 bit 11 bit 10 bit 9 bit 8 bit 7 bit 6 bit 5 bit 4 bit 3 bit 2 bit 1 bit 0 SCRn, SMRn PEN SBL AD CRE RXE TXE MD1 MD0 OTO EXT REST UPCL SCKE SOE Mode 1 0 0 0 0 0 0 0 0 0 Х 0 0 0 SSRn, TDRn/RDRn Set conversion data (during writing) PΕ ORE FRE RDRF TDRE BDS RIE TIE Retain reception data (during reading) Mode 1 0 0 ESCRn, ECCRn BIE LBD LBL1 LBL0|SOPE|SIOP|CCO|SCES SCDE SSM TBI Mode 1 0 @: Used bit x: Unused bit 1: Set 1 0: Set 0 n = 0, 1+ : Bit automatically set to correct value

Figure 20.7-13 Settings for LIN-UART Operation Mode 1

#### Inter-CPU connection

As shown in Figure 20.7-14, a communication system consists of one master CPU and multiple slave CPUs connected to two communication lines. LIN-UART can be used for the master or slave CPU.



Figure 20.7-14 Connection Example of LIN-UART Master-slave Communication

#### Function selection

Select the operation mode and data transfer mode for master-slave communication as shown in Table 20.7-3.

Table 20.7-3 Selection of the Master-slave Communication Function

|                                          | Operati       | on mode                                     | Data                               | Parity | Parity Synchron Stop bit ization |                 | Bit direction       |
|------------------------------------------|---------------|---------------------------------------------|------------------------------------|--------|----------------------------------|-----------------|---------------------|
|                                          | Master<br>CPU | Slave<br>CPU                                |                                    |        | method                           |                 |                     |
| transmission and                         | receive AD-   | Mode 1<br>(transmit/<br>receive AD-<br>bit) | AD="1"<br>+<br>7- or 8-bit address | None   | Asynchro-<br>nous                | 1 bit or 2 bits | LSB or MSB<br>first |
| Data<br>transmission<br>and<br>reception |               |                                             | AD="0"<br>+<br>7- or 8-bit data    |        |                                  |                 |                     |

#### Communication procedure

When the master CPU transmits address data, communication starts. The AD bit in the address data is set to 1, and the communication destination slave CPU is selected. Each slave CPU checks the address data using a program. When the address data indicates the address assigned to a slave CPU, the slave CPU communicates with the master CPU.

Figure 20.7-15 shows a flowchart of master-slave communication (multiprocessor mode)



Figure 20.7-15 Master-slave Communication Flowchart

### 20.7.7 LIN Communication Function

LIN-UART communication with LIN devices is available for both LIN master or LIN slave systems.

#### **■ LIN-master-slave Communication Function**

The settings shown in the figure below are required to operate LIN-UART in LIN communication mode (operation mode 3).

Figure 20.7-16 Settings for LIN-UART in Operation Mode 3 (LIN)



#### LIN device connection

As shown in the Figure below, a communication system of one LIN-Master device and a LIN-Slave device. LIN-UART can operate both as LIN-Master or LIN-Slave.

Figure 20.7-17 Connection Example of a Small LIN-Bus System



# 20.7.8 Sample Flowcharts for LIN-UART in LIN communication (Operation Mode 3)

This section contains sample flowcharts for LIN-UART in LIN communication.

#### ■ LIN-UART as LIN Master Device

Figure 20.7-18 LIN-UART LIN Master Flowchart



#### ■ LIN-UART as LIN slave device

Start Initial setting: Set operation mode 3 Serial data output enabled TXE = 1, TIE = 0, RXE = 0, RIE = 1Connection with LIN-UART and ICU Reception prohibited ICU interrupt enabled Synch break interrupt enabled (transmission) (reception) Data Field LBD = 1reception?<sup>N</sup> Synch break interrupt Reception interrupt Synch Break detection clear ECCR: LBD = 0 Transmission data 1 set Data 1 reception\*1 Synch break interrupt pro-TDR = Data 1 hibited Transmission interrupt RDRF = 1enabled Reception interrupt ICU interrupt TDRE = 1Transmission interrupt Data N reception\*1 ICU data read Transmission data N set ICU interrupt flag clear TDR = Data N Transmission interrupt pro-ICU interrupt hibited Reception prohibited RDRF = 1ICU data read Reception interrupt Baud rate regulation Reception enabled Data 1 reception\*1 ICU interrupt flag clear ICU interrupt prohibited Data 1 read RDRF = 1RDRF = 1Reception interrupt Reception interrupt Data N reception\*1 Identify field reception\*1 Data N read Reception prohibited Sleep mode? Without error? N Error processing\*2 Wake up reception? ₩ake up transmission? Wake up code transmission \*1: If an error occurs, perform the error processing • When fre and ore is "1", write 1 to SCR: CRE bit and clear the error flag. • When ESCR: LBD bit is "1", execute UART reset. Note: The error is detected in each processing and take appropriate measure.

# 20.8 Notes on Using LIN-UART

#### Notes on using LIN-UART are given below.

#### ■ Notes on Using LIN-UART

#### Enabling operations

In LIN-UART, the serial control register (SCR) has TXE (transmission) and RXE (reception) operation enable bits. Both, transmission and reception operations, must be enabled before the communication starts because they have been disabled as the default value (initial value). The operation can also be canceled by disabling these bits.

#### Communication mode setting

Set the communication mode while the system is not operating. If the mode is changed during transmission or reception, the transmission or reception is stopped and possible data will be lost.

#### Transmission interrupt enabling timing

The default (initial value) of the transmission data empty flag bit (SSR: TDRE) is "1" (no transmission data and transmission data write enable state). A transmission interrupt request is generated as soon as the transmission interrupt request is enabled (SSR: TIE=1). Be sure to set the TIE flag to "1" after setting the transmission data to avoid an immediate interrupt.

#### Changing operation settings

It is strongly recommended to reset LIN-UART after changing operation settings. Particularly if (for example) start-/stop-bits added to or removed from the data format.

If settings in the serial mode register (SMR) are desired, it is not useful to set the UPCL bit to 1 at the same time to reset LIN-UART. The correct operation settings are not guaranteed in this case. Thus it is recommended to set the bits of the SMR and then to reset them again plus the UPCL bit.

#### Using LIN operation mode 3

The LIN features are available in mode 3 (transmitting, receiving synch break), but using mode 3 sets the UART data format automatically to LIN format (8N1, LSB first). Note that the length of the synch break for transmission is variable but for reception it is fixed 11-bit time.

#### LIN slave settings

Set the baud rate before receiving the first LIN synch break for the slave operation. This is needed to detect the minimum of 13-bit time of a LIN synch break surely.

#### Software compatibility

Although this LIN-UART is similar to other LIN-UART in other microcontrollers, it is not software compatible to them. The programming models may be the same, but the structure of the registers differ. Furthermore, the setting of the baud rate is now determined by a reload value instead of selecting a

predefined value.

#### Bus idle function

The bus idle function cannot be used in synchronous mode 2.

#### AD bit (serial control register (SCR): address/data type select bit)

Special care has to be taken when using the AD bit (Address-Data-Bit for multiprocessor mode 1) of the Serial Control Register. This bit is both a control and a flag bit, because writing to it sets the AD bit for transmission, whereas reading from it returns the last received AD bit. Internally, the received and the transmitted value are stored in different registers, but in Read-Modify-Write instructions, the transmitted value is read. This can lead to a wrong value in the AD bit, when one of the other bits in the same register is accessed by an instruction of this kind.

Therefore, this bit should be written by the last register access before transmission. Alternatively, using byte wise access and writing the correct values for all bits at once avoids this problem.

#### Software reset of LIN-UART

Perform the software reset (SMR: UPCL=1), when the TXE bit of the SCR register is "0".

#### LIN Synch detection

In mode 3 (LIN operation), the LBD bit in the ESCR register is set to "1" if the input signal is kept at "0" for more than equal to 11-bit time. Then the LIN-UART waits for the following synch field to be received. If the LIN-UART is set into this state for other reasons than the synch break, it recognizes that synch break is inputted (LBD = 1) and waits for synch field.

In this case, execute the LIN-UART reset (SMR: UPCL = 1).

# **CHAPTER 21**

# CAN CONTROLLER

This chapter explains the functions and operations of the CAN controller.

- 21.1 Features of CAN Controller
- 21.2 Block Diagram of CAN Controller
- 21.3 List of Overall Control Registers
- 21.4 Classifying CAN Controller Registers
- 21.5 Transmission of CAN Controller
- 21.6 Reception of CAN Controller
- 21.7 Reception Flowchart of CAN Controller
- 21.8 How to Use CAN Controller
- 21.9 Procedure for Transmission by Message Buffer (x)
- 21.10 Procedure for Reception by Message Buffer (x)
- 21.11 Setting Configuration of Multi-level Message Buffer
- 21.12 Setting the CAN Direct Mode Register
- 21.13 Precautions when Using CAN Controller

### 21.1 Features of CAN Controller

The CAN (Controller Area Network) is the standard protocol for serial communication between automobile controllers and is widely used in industrial applications.

#### **■** Features of CAN Controller

- Conforms to CAN Specification Version 2.0 Part A and B
   Supports transmission/reception in standard frame and extended frame formats
- Supports transmitting of data frames by receiving remote frames
- 16 transmitting/receiving message buffers
  - 29-bit ID and 8 bytes data
  - Multi-level message buffer configuration
- Supports full-bit comparison, full-bit mask and partial bit mask filtering

  Two acceptance mask registers in either standard frame format or extended frame formats
- Bit rate programmable from 10 Kbps to 1 Mbps (Minimum 8 MHz machine clock is required at using 1 Mbps.)

# 21.2 Block Diagram of CAN Controller

Figure 21.2-1 shows a block diagram of the CAN controller.

#### **■** Block Diagram of CAN Controller

Figure 21.2-1 Block Diagram of CAN Controller



# 21.3 List of Overall Control Registers

Following Table lists the register.

### ■ List of overall Control Registers

Table 21.3-1 List of overall Control Register (1 / 2)

| Address             | Pogistor                                | Abbreviation A | Λοοοοο | Initial Value            |  |
|---------------------|-----------------------------------------|----------------|--------|--------------------------|--|
| CAN1                | Register                                |                | Access |                          |  |
| 000080 <sub>H</sub> | Massaga hyffar yelid register           | BVALR          | R/W    | 00000000000000000        |  |
| 000081 <sub>H</sub> | Message buffer valid register           | DVALK          | IX/ VV |                          |  |
| 000082 <sub>H</sub> | Transmit request register               | TREQR          | R/W    | 00000000000000000        |  |
| 000083 <sub>H</sub> | Transmit request register               | TREQR          | IC/ VV |                          |  |
| 000084 <sub>H</sub> | Transmit cancel register                | TCANR          | W      | 00000000000000000        |  |
| 000085 <sub>H</sub> | Transmit cancer register                | TCAIVK         | **     |                          |  |
| 000086 <sub>H</sub> | Transmit complete register              | TCR            | R/W    | 00000000000000000        |  |
| 000087 <sub>H</sub> | Transmit complete register              | TCR            | 10, 11 |                          |  |
| 000088 <sub>H</sub> | Receive complete register               | RCR            | R/W    | 00000000000000000        |  |
| 000089 <sub>H</sub> | receive complete register               | non            | 10 ()  |                          |  |
| 00008A <sub>H</sub> | Remote request receiving                | RRTRR          | R/W    | 00000000000000000        |  |
| 00008B <sub>H</sub> | register                                | KKIKK          | 10 11  |                          |  |
| 00008C <sub>H</sub> | Receive overrun register                | ROVRR          | R/W    | 0000000000000000         |  |
| 00008D <sub>H</sub> | receive overruin register               |                |        |                          |  |
| 00008E <sub>H</sub> | Receive interrupt enable register       | RIER           | R/W    | 00000000 00000000        |  |
| 00008F <sub>H</sub> | Trees to miles up on up to register     |                |        |                          |  |
| 007D00 <sub>H</sub> | Control status register                 | CSR            | R/W, R | 0 0 XXX 0 0 0 0 XXXX0 X1 |  |
| 007D01 <sub>H</sub> | Control status register                 |                |        |                          |  |
| 007D02 <sub>H</sub> | Last event indicator register           | LEIR           | R/W    | XXXXXXXX 000X000         |  |
| 007D03 <sub>H</sub> | Zust e vent morenter register           | 2211           | 10 //  | MAMAMA 000 NO 000        |  |
| 007D04 <sub>H</sub> | Receive/transmit error counter          | RTEC           | R      | 00000000000000000        |  |
| 007D05 <sub>H</sub> | receive, transmit error counter         | RILE           |        |                          |  |
| 007D06 <sub>H</sub> | Bit timing register                     | BTR            | R/W    | X11111111111111          |  |
| 007D07 <sub>H</sub> | 210 01111111111111111111111111111111111 | 211            |        | M111111111111111         |  |
| 007D08 <sub>H</sub> | · IDE register                          | IDER           | R/W    | XXXXXXXX XXXXXXXX        |  |
| 007D09 <sub>H</sub> | 122 12510101                            |                | 20 11  |                          |  |
| 007D0A <sub>H</sub> | Transmit RTR register                   | TRTRR          | R/W    | 00000000000000000        |  |
| 007D0B <sub>H</sub> | Timbinit Terrerogiotor                  | ININ           | IX/ VV |                          |  |

Table 21.3-1 List of overall Control Register (2 / 2)

| Address             | - Register                      | Abbreviation | Access | Initial Value     |  |
|---------------------|---------------------------------|--------------|--------|-------------------|--|
| CAN1                | Register                        | Abbreviation | Access |                   |  |
| 007D0C <sub>H</sub> | Remote frame receive waiting    | RFWTR R/V    | R/W    | XXXXXXXX XXXXXXXX |  |
| 007D0D <sub>H</sub> | register                        | KIWIK        | K/W    |                   |  |
| 007D0E <sub>H</sub> | Transmit interrupt enable       | TIER         | R/W    | 00000000000000000 |  |
| 007D0F <sub>H</sub> | register                        | TILK         | IV/ VV |                   |  |
| 007D10 <sub>H</sub> |                                 |              |        | XXXXXXXX XXXXXXX  |  |
| 007D11 <sub>H</sub> | Acceptance mask select register | AMSR         | R/W    |                   |  |
| 007D12 <sub>H</sub> |                                 |              |        | XXXXXXXX XXXXXXXX |  |
| 007D13 <sub>H</sub> |                                 |              |        |                   |  |
| 007D14 <sub>H</sub> |                                 | AMRO R       | R/W    | XXXXXXXX XXXXXXX  |  |
| 007D15 <sub>H</sub> | Acceptance mask register 0      |              |        |                   |  |
| 007D16 <sub>H</sub> | Acceptance mask register o      | AWIKU        | IX/ VV | XXXXXXXX XXXXXXX  |  |
| 007D17 <sub>H</sub> |                                 |              |        |                   |  |
| 007D18 <sub>H</sub> |                                 |              |        | XXXXXXXX XXXXXXX  |  |
| 007D19 <sub>H</sub> | Acceptance mask register 1      | AMR1         | R/W    |                   |  |
| 007D1A <sub>H</sub> |                                 | AMKI         | K/W    | XXXXXXXX XXXXXXXX |  |
| 007D1B <sub>H</sub> |                                 |              |        |                   |  |

# ■ List of Message Buffers (ID registers)

Table 21.3-2 List of Message Buffers (ID registers) (1 / 2)

| Address                                          | Donistan            | A la la vas si a ti a sa | A      | In Male Co                 |
|--------------------------------------------------|---------------------|--------------------------|--------|----------------------------|
| CAN1                                             | Register            | Abbreviation             | Access | Initial Value              |
| 007C00 <sub>H</sub><br>to<br>007C1F <sub>H</sub> | General-purpose RAM | -                        | R/W    | XXXXXXXX<br>to<br>XXXXXXXX |
| 007C20 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXX           |
| 007C21 <sub>H</sub>                              | ID register 0       | IDR0                     | R/W    |                            |
| 007C22 <sub>H</sub>                              | in register o       |                          | TO W   | XXXXXXXX XXXXXXXX          |
| 007C23 <sub>H</sub>                              |                     |                          |        |                            |
| 007C24 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXX           |
| 007C25 <sub>H</sub>                              | ID register 1       | IDR1                     | R/W    |                            |
| 007C26 <sub>H</sub>                              |                     |                          |        | xxxxxxx xxxxxxx            |
| 007C27 <sub>H</sub>                              |                     |                          |        |                            |
| 007C28 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXX           |
| 007C29 <sub>H</sub>                              | ID register 2       | IDR2                     | R/W    |                            |
| 007C2A <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXX           |
| 007C2B <sub>H</sub>                              |                     |                          |        |                            |
| 007C2C <sub>H</sub>                              |                     | IDR3                     | R/W    | XXXXXXXX XXXXXXXX          |
| 007C2D <sub>H</sub>                              | ID register 3       |                          |        |                            |
| 007C2E <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C2F <sub>H</sub>                              |                     |                          |        |                            |
| 007C30 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C31 <sub>H</sub>                              | ID register 4       | IDR4                     | R/W    |                            |
| 007C32 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C33 <sub>H</sub>                              |                     |                          |        |                            |
| 007C34 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C35 <sub>H</sub>                              | ID register 5       | IDR5                     | R/W    |                            |
| 007C36 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C37 <sub>H</sub>                              |                     |                          |        |                            |
| 007C38 <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 007C3A <sub>H</sub>                              | ID register 6       | IDR6                     | R/W    |                            |
| 007C3A <sub>H</sub>                              |                     |                          |        | XXXXXXXX XXXXXXXX          |
| 507.03 <b>2</b> H                                |                     |                          |        |                            |

Table 21.3-2 List of Message Buffers (ID registers) (2 / 2)

| Address                                    | Dominton       | A la la vas via ti a va | A      | In Male Value     |
|--------------------------------------------|----------------|-------------------------|--------|-------------------|
| CAN1                                       | Register       | Abbreviation            | Access | Initial Value     |
| 007C3C <sub>H</sub>                        |                |                         |        | VVVVVVV VVVVVVV   |
| 007C3D <sub>H</sub>                        | ID register 7  | IDR7                    | R/W    | XXXXXXXX XXXXXXXX |
| 007C3E <sub>H</sub>                        | in register /  | IDK/                    | IN/ W  | XXXXXXXX XXXXXXX  |
| 007C3F <sub>H</sub>                        |                |                         |        |                   |
| 007C40 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C41 <sub>H</sub>                        | ID register 8  | IDR8                    | R/W    |                   |
| 007C42 <sub>H</sub>                        | in register o  |                         | 10 11  | XXXXXXXX XXXXXXXX |
| 007C43 <sub>H</sub>                        |                |                         |        |                   |
| 007C44 <sub>H</sub>                        |                |                         |        | xxxxxxx xxxxxxx   |
| 007C45 <sub>H</sub>                        | ID register 9  | IDR9                    | R/W    |                   |
| 007C46 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C47 <sub>H</sub>                        |                |                         |        |                   |
| 007C48 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C49 <sub>H</sub>                        | ID register 10 | IDR10                   | R/W    |                   |
| 007C4A <sub>H</sub><br>007C4B <sub>H</sub> |                |                         |        | XXXXXXXX XXXXXXX  |
| 007C4C <sub>H</sub>                        |                |                         |        |                   |
| 007C4C <sub>H</sub>                        | -              | IDR11                   | R/W    | XXXXXXXX XXXXXXXX |
| 007C4E <sub>H</sub>                        | ID register 11 |                         |        |                   |
| 007C4F <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXX  |
| 007C50 <sub>H</sub>                        |                |                         |        |                   |
| 007C51 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C52 <sub>H</sub>                        | ID register 12 | IDR12                   | R/W    |                   |
| 007C53 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C54 <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXX  |
| 007C55 <sub>H</sub>                        | ID register 13 | IDR13                   | R/W    |                   |
| 007C56 <sub>H</sub>                        | 12 10510101 10 |                         |        | XXXXXXXX XXXXXXX  |
| 007C57 <sub>H</sub>                        |                |                         |        |                   |
| 007C58 <sub>H</sub>                        |                |                         |        | xxxxxxx xxxxxxx   |
| 007C59 <sub>H</sub>                        | ID register 14 | IDR14                   | R/W    |                   |
| 007C5A <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXX  |
| 007C5B <sub>H</sub>                        |                |                         |        |                   |
| 007C5C <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| 007C5D <sub>H</sub><br>007C5E <sub>H</sub> | ID register 15 | IDR15                   | R/W    |                   |
| 007C5E <sub>H</sub>                        |                |                         |        | XXXXXXXX XXXXXXXX |
| UU/CJFH                                    |                |                         |        |                   |

# ■ List of Message Buffers (DLC registers and data registers)

Table 21.3-3 List of Message Buffer (DLC register and data register)

| Address                                    | Dominton        | Abbreviation | A      | Initial Value |  |
|--------------------------------------------|-----------------|--------------|--------|---------------|--|
| CAN1                                       | Register        | Abbreviation | Access | Initial Value |  |
| 007C60 <sub>H</sub>                        | DI C marietan O | DLCR0        | R/W    | VVVVVVV       |  |
| 007C61 <sub>H</sub>                        | DLC register 0  |              |        | XXXXXXX       |  |
| 007C62 <sub>H</sub>                        | DLC register 1  | DLCR1        | R/W    | VVVVVVV       |  |
| 007C63 <sub>H</sub>                        | DLC register 1  | DLCKI        | IX/ VV | XXXXXXXX      |  |
| 007C64 <sub>H</sub>                        | DLC register 2  | DLCR2        | R/W    | XXXXXXXX      |  |
| 007C65 <sub>H</sub>                        | DLC register 2  | DECKZ        | IV/ VV | XXXXXXX       |  |
| 007C66 <sub>H</sub>                        | DLC register 3  | DLCR3        | R/W    | XXXXXXX       |  |
| 007C67 <sub>H</sub>                        | DEC TOSISTOL S  | BECKS        | 10 11  | 1             |  |
| 007C68 <sub>H</sub>                        | DLC register 4  | DLCR4        | R/W    | XXXXXXX       |  |
| 007C69 <sub>H</sub>                        |                 |              |        |               |  |
| 007C6A <sub>H</sub>                        | DLC register 5  | DLCR5        | R/W    | XXXXXXX       |  |
| 007C6B <sub>H</sub>                        | C               |              |        |               |  |
| 007C6C <sub>H</sub>                        | DLC register 6  | DLCR6        | R/W    | XXXXXXX       |  |
| 007C6D <sub>H</sub>                        |                 |              |        |               |  |
| 007C6E <sub>H</sub>                        | DLC register 7  | DLCR7        | R/W    | XXXXXXX       |  |
| 007C6F <sub>H</sub>                        |                 |              |        |               |  |
| 007C70 <sub>H</sub>                        | DLC register 8  | DLCR8        | R/W    | XXXXXXX       |  |
| 007C71 <sub>H</sub>                        |                 |              |        |               |  |
| 007C72 <sub>H</sub><br>007C73 <sub>H</sub> | DLC register 9  | DLCR9        | R/W    | XXXXXXX       |  |
| 007C73 <sub>H</sub>                        |                 |              |        |               |  |
| 007C74 <sub>H</sub>                        | DLC register 10 | DLCR10       | R/W    | XXXXXXX       |  |
| 007C75 <sub>H</sub>                        |                 |              |        |               |  |
| 007C77 <sub>H</sub>                        | DLC register 11 | DLCR11       | R/W    | XXXXXXX       |  |
| 007C78 <sub>H</sub>                        |                 |              |        |               |  |
| 007C79 <sub>H</sub>                        | DLC register 12 | DLCR12       | R/W    | XXXXXXX       |  |
| 007C7A <sub>H</sub>                        |                 |              |        |               |  |
| 007C7B <sub>H</sub>                        | DLC register 13 | DLCR13       | R/W    | XXXXXXXX      |  |
| 007C7C <sub>H</sub>                        |                 |              |        |               |  |
| 007C7D <sub>H</sub>                        | DLC register 14 | DLCR14       | R/W    | XXXXXXX       |  |
| 007C7E <sub>H</sub>                        | DI Consistentis | DI CD17      | D/W    | VVVVVVV       |  |
| 007C7F <sub>H</sub>                        | DLC register 15 | DLCR15       | R/W    | XXXXXXXX      |  |

# ■ List of Message Buffer (data register)

Table 21.3-4 List of Message Buffer (data register)

| Address                                       | Decistor                     | A b b revietien | Λ      | Initial Value           |
|-----------------------------------------------|------------------------------|-----------------|--------|-------------------------|
| CAN1                                          | Register                     | Abbreviation    | Access | Initial Value           |
| 007C80 <sub>H</sub> to<br>007C87 <sub>H</sub> | Data register 0 (8 bytes)    | DTR0            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007C88 <sub>H</sub> to<br>007C8F <sub>H</sub> | Data register 1 (8 bytes)    | DTR1            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007C90 <sub>H</sub> to<br>007C97 <sub>H</sub> | Data register 2<br>(8 bytes) | DTR2            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007C98 <sub>H</sub> to<br>007C9F <sub>H</sub> | Data register 3 (8 bytes)    | DTR3            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CA0 <sub>H</sub> to<br>007CA7 <sub>H</sub> | Data register 4 (8 bytes)    | DTR4            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CA8 <sub>H</sub> to<br>007CAF <sub>H</sub> | Data register 5 (8 bytes)    | DTR5            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CB0 <sub>H</sub> to<br>007CB7 <sub>H</sub> | Data register 6 (8 bytes)    | DTR6            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CB8 <sub>H</sub> to<br>007CBF <sub>H</sub> | Data register 7 (8 bytes)    | DTR7            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CC0 <sub>H</sub> to<br>007CC7 <sub>H</sub> | Data register 8 (8 bytes)    | DTR8            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CC8 <sub>H</sub> to<br>007CCF <sub>H</sub> | Data register 9 (8 bytes)    | DTR9            | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CD0 <sub>H</sub> to<br>007CD7 <sub>H</sub> | Data register 10 (8 bytes)   | DTR10           | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CD8 <sub>H</sub> to<br>007CDF <sub>H</sub> | Data register 11 (8 bytes)   | DTR11           | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CE0 <sub>H</sub> to<br>007CE7 <sub>H</sub> | Data register 12 (8 bytes)   | DTR12           | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CE8 <sub>H</sub> to<br>007CEF <sub>H</sub> | Data register 13 (8 bytes)   | DTR13           | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CF0 <sub>H</sub> to<br>007CF7 <sub>H</sub> | Data register 14 (8 bytes)   | DTR14           | R/W    | XXXXXXXX to<br>XXXXXXXX |
| 007CF8 <sub>H</sub> to<br>007CFF <sub>H</sub> | Data register 15 (8 bytes)   | DTR15           | R/W    | XXXXXXXX to<br>XXXXXXXX |

# 21.4 Classifying CAN Controller Registers

#### There are 3 types of CAN controller registers;

- Overall control registers
- Message buffer control registers
- Message buffers

#### ■ Overall Control Registers

The overall control registers are the following 4 registers;

- Control status register (CSR)
- Last event indicator register (LEIR)
- Receive and transmit error counter (RTEC)
- Bit timing register (BTR)

#### ■ Message Buffer Control Registers

The message buffer control registers are the following 14 registers;

- Message buffer valid register (BVALR)
- IDE register (IDER)
- Transmission request register (TREQR)
- Transmission RTR register (TRTRR)
- Remote frame receiving wait register (RFWTR)
- Transmission cancel register (TCANR)
- Transmission complete register (TCR)
- Transmission interrupt enable register (TIER)
- Reception complete register (RCR)
- Remote request receiving register (RRTRR)
- Receive overrun register (ROVRR)
- Reception interrupt enable register (RIER)
- Acceptance mask select register (AMSR)
- Acceptance mask registers 0 and 1 (AMR0 and AMR1)

#### ■ Message Buffers

The message buffers are the following 3 registers;

- ID register x (x = 0 to 15) (IDRx)
- DLC register x (x = 0 to 15) (DLCRx)
- Data register x (x = 0 to 15) (DTRx)

# 21.4.1 Configuration of Control Status Register (CSR)

This register indicates bus operation, node status, transmit output enable and transmit/receive status. The lower 8-bit with the control status register (CSR) is prohibited from executing any bit manipulation instructions (Read-Modify-Write instructions). Only in the case of HALT bits unchanged (initialization of the macro instructions etc.), there is no problem even if any bit manipulation instructions is used.

# ■ Control Status Register (CSR) (Lower)

Address CSR1 (Lower) Reset Vaue NIE Re-CAN1: 007D00<sub>H</sub> TOE HALT 0 X X X X 0 X 1 B bit0 HALT Bus operation styop bit Write: Stop of bus operation is released. Read:The state of bus operation is not stop mod Write: Stops bus operation Read: Bus operation in stop mode bit1 Reserved bit Reserved 0 Always write "0" to this bit hit2 NIE Node status transition interrupt enable 0 Node status transition interrupt enabled 1 Node status transition interrupt disabled

TOE

0

Transmit output enable

General-purpose port pin

Transmit pin of TX

Figure 21.4-1 Configuration of the Control Status Register (lower byte)

# ■ Control Status Register (CSR) (upper)

R/W: Read/Writ

Х

Write only

: Undefined : Unused : Reset value



Figure 21.4-2 Configuration of the Control Status Register (upper byte)

# 21.4.2 Function of Control Status Register (CSR)

The operating status of the register's each bit is confirmed by following;

- Setting "0" or "1"
- Function control by writing
- Read

# **■** Control Status Register (CSR-lower)

Table 21.4-1 Function of Each Bit of the Control Status Register (CSR:L)

|                 | Bit Name                                                         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7            | TOE:<br>Transmit output<br>enable bit                            | This bit switches from a general-purpose I/O port to a transmit pin TX.  When setting to 0: Functions as general-purpose I/O port.  When setting to 1: Functions as transmit pin TX.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| bit6 to<br>bit3 | Undefined bits                                                   | When reading: Value is undefined. When writing: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| bit2            | NIE:<br>Node status<br>transition interrupt<br>output enable bit | This bit controls a node status transition interrupt generation (CSR: NT = 1) when a node status is transferred.  When setting to 0: Interrupt generation is disabled.  When setting to 1: Interrupt generation is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| bit1            | Reserved:<br>Reserved bit                                        | This bit is always set to 0.  When reading: The value is always 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| bit0            | HALT:<br>Bus operation halt<br>bit                               | This bit controls the bus halt. The halt state of the bus can be checked by reading this bit.  Writing to this bit:  0: Cancels bus halt  1: Halt bus  Reading from this bit:  0: Bus operation not in stop state  1: Bus operation in stop state  Note: After ensuring that 1 is written to this bit, write 0 to this bit if the node status is Bus Off.  Example program: switch (IO_CANCT1.CSR.bit.NS) {  case 0: /* error active */ break; case 1: /* warning */ break; case 2: /* error passive */ break; default: /* bus off */ for (i=0; (i <= 500)    (IO_CANCT1.CSR.bit.HALT == 0); i++); IO_CANCT1.CSR.word = 0x0084; /* HALT = 0 */ break; }  *: The variable "i" is used for fail-safe. For detail information, see "21.4.4 Notes on Using Bus Operation Stop Bit (HALT = 1)". |

# ■ Control status register (CSR-upper)

Table 21.4-2 Function of Each Bit of the Control Status Register (CSR:H)

|                      | Bit Name                              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |
|----------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| bit15                | TS:<br>Transmit status<br>bit         | This bit indicates whether a message is being transmitted.  At read:  0: Message not being transmitted  1: Message being transmitted  This bit is set 0 even while error and overload frames are transmitted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| bit14                | RS:<br>Receive status bit             | <ul> <li>This bit indicates whether a message is being received.</li> <li>At read: <ul> <li>0: Message not being received</li> <li>1: Message being received</li> </ul> </li> <li>While a message is on the bus, this bit becomes 1. Therefore, this bit is also 1 while a message is being transmitted. This bit does not necessarily indicates whether a receiving message passes through the acceptance filter.</li> <li>As a result, when this bit is 0, it implies that the bus operation is stopped (HALT = 1); the bus is in the intermission/bus idle or a error/overload frame is on the bus.</li> </ul>                                                                                                                                                    |  |  |  |  |  |
| bit13<br>to<br>bit11 | Undefined bits                        | When reading: The value is undefined. When writing: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |  |  |
| bit10                | NT:<br>Node status<br>transition flag | When the node status changes from increment transition or off bus into error active, this bit is set to "1". The condition that this bit is set to "1" is as follows. At this time, the interruption is generated for the node status interruption permission bit (NIE) = "1".  1) Error active (" $00_B$ ") $\rightarrow$ Warning (" $01_B$ ")  2) Warning (" $01_B$ ") $\rightarrow$ Error passive (" $10_B$ ")  3) Error passive (" $10_B$ ") $\rightarrow$ Bus off (" $11_B$ ")  4) Bus off (" $11_B$ ") $\rightarrow$ Error active (" $00_B$ ")  Note: In parentheses, the value of NS1 and the NS0 bit is indicated.  At Write:  "0": Cleared "1": Not possible to set (No effect)  At read by the instruction of the read-modify-write type: Always read "1". |  |  |  |  |  |
| bit9<br>bit8         | NS1, NS0:<br>Node status bits         | These bits indicate the current node status. For detail information, see "21.4.3 Correspondence between Node Status Bit and Node Status".                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |

# 21.4.3 Correspondence between Node Status Bit and Node Status

Node status bit shows the node status by two bits (NS1 and NS0).

### **■** Correspondence between Node Status Bit and Node Status

Table 21.4-3 Correspondence between NS1 and NS0 and Node Status

| NS1 | NS0 | Node status            |
|-----|-----|------------------------|
| 0   | 0   | Error active           |
| 0   | 1   | Warning (error active) |
| 1   | 0   | Error passive          |
| 1   | 1   | Bus off                |

#### Note:

Warning (error active) is included in the error active in CAN Specification 2.0B for the node status, however, indicates that the transmit error counter or receive error counter has exceeded 96. The node status change diagram is shown in Figure 21.4-3.

Figure 21.4-3 Node Status Transition Diagram Hardware reset It is necessary to cancel the bus operation halt for the shift. REC: Receive error counter Error active TEC: Transmit error counter REC ≥ 96 or TEC ≥ 96 REC < 96 After 0 has been written to the HALT bit of and TEC < 96 the register (CSR), continuous 11-bit High Warning levels (recessive bits) are input 128 times to the the shift. (Error active) REC ≥ 128 or TEC ≥ 128 **REC < 128** and TEC < 128 Bus off Error passive (HALT=1) TEC ≥ 256

# 21.4.4 Notes on Using Bus Operation Stop Bit (HALT = 1)

The bus operation stop bit is set by writing to the bit, hardware reset and the node status. The stop operation of the bus operation is different according to the state of the message buffer.

### ■ Conditions for Setting Bus Operation Stop (HALT=1)

There are 3 conditions for setting bus operation stop (HALT = 1):

- · After hardware reset
- · When node status changed to bus off
- By writing 1 to HALT

#### **Notes:**

- The bus operation should be stopped by writing 1 to HALT before the F<sup>2</sup>MC-16LX is changed in low-power consumption mode (stop mode and timebase timer mode). If transmission is in progress when 1 is written to HALT, the bus operation is stopped (HALT = 1) after transmission is terminated. If reception is in progress when 1 is written to HALT, the bus operation is stopped immediately (HALT = 1). If received messages are being stored in the message buffer (x), stop the bus operation (HALT = 1) after storing the messages.
- To check whether the bus operation has stopped, always read the HALT bit.

### ■ Conditions for Canceling Bus Operation Stop (HALT = 0)

The condition for canceling the bus operation if halt is writing 0 to HALT.

#### Notes:

- Canceling the bus operation stop after hardware reset or by writing 1 to HALT as above conditions is performed after 0 is written to HALT and continuous 11-bit High levels (recessive bits) have been input to the receive input pin (RX) (HALT = 0).
- Canceling the bus operation stop when the node status is changed to bus off as above conditions is performed after 0 is written to HALT and continuous 11-bit High levels (recessive bits) have been input 128 times to the receive input pin (RX) (HALT = 0). Then, the values of both transmit and receive error counters reach 0 and the node status is changed to error active.
- When write 0 to HALT during the node status is Bus Off, ensure that 1 is written to this bit.

# ■ State during Bus Operation Stop (HALT = 1)

- The bus does not perform any operation, such as transmission and reception.
- The transmit output pin (TX) outputs a High level (recessive bit).
- The values of other registers and error counters are not changed.

#### Note:

The bit timing register (BTR) should be set during bus operation stop (HALT = 1).

# 21.4.5 Last Event Indicator Register (LEIR)

This register indicates the last event.

The NTE, TCE, and RCE bits are exclusive. When the corresponding bit of the last event is set to 1, other bits are set to 0.

#### ■ Last Event Indicator Register (LEIR)

Figure 21.4-4 Configuration of the Last Event Indicator Register (LEIR)



# ■ Last Event Indicator Register (LEIR)

Table 21.4-4 Function of Each Bit of the Last Event Indicator Register (LEIR) (1 / 2)

|      | Bit Name                                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|------|---------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit7 | NTE:<br>Node status transition<br>event bit | When this bit is 1, node status transition is the last event.  This bit is set to 1 after set either of bit of the control status register to "1" (CSR:NTx=1).  • This setting is not related to the setting of NIE bit of the control status register (CSR).  At Write:  "0": Cleared  "1": No effect  At read by the instruction of the read-modify-write type:  Always read "1".                                                                                                                                                                                                                      |  |  |  |  |
| bit6 | TCE:<br>Transmit completion<br>event bit    | <ul> <li>When this bit is 1, it indicates that transmit completion is the last event. This bit is set to 1 after set either of bit of the transmit completion register to "1" (TCR:TCx=1).</li> <li>This setting is not related to the setting of the transmit interrupt enable register (TIER).</li> <li>When this bit is "1", MBP3 to MBP0 bits show the message buffer number (x) to complete the transmission of the message in the last event. At Write:     "0": Cleared     "1": No effect At read by the instruction of the read-modify-write type:     Always read "1".</li> </ul>              |  |  |  |  |
| bit5 | RCE:<br>Receive completion<br>event bit     | <ul> <li>When this bit is 1, it indicates that receive completion is the last event. This bit is set to 1 after set either of bit of the receive complete register to "1" (RCR:RCx=1).</li> <li>This setting is not related to the setting of the receive interrupt enable register (RIER).</li> <li>When this bit is "1", MBP3 to MBP0 bits show the message buffer number (x) to complete the transmission of the message in the last event.</li> <li>At Write:     "0": Cleared     "1": No effect</li> <li>At read by the instruction of the read-modify-write type:     Always read "1".</li> </ul> |  |  |  |  |
| bit4 | Undefined bit                               | When reading: The value is undefined. When writing: No effect                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |

Table 21.4-4 Function of Each Bit of the Last Event Indicator Register (LEIR) (2 / 2)

|                    | Bit Name                                        | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------------------|-------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit3<br>to<br>bit0 | MBP3 to MBP0:<br>Message buffer<br>pointer bits | When TCE bit or RCE bit is "1", these bits show the message buffer number (x) to generating of corresponding the last event. If the NTE bit is set to 1, these bits have no meaning.  At Write:  "0": Cleared  "1": No effect  At read by the instruction of the read-modify-write type:  Always read "1".  Note:  If LEIR is accessed within an CAN interrupt handler, the event causing the interrupt is not necessarily the same as indicated by LEIR. In the time from interrupt request to the LEIR access by the interrupt handler there may occur other CAN events. |

# 21.4.6 Receive and Transmit Error Counters (RTEC)

The receive and transmit error counters indicate the counts for transmission errors and reception errors defined in the CAN specifications. These registers can only be read.

# **■** Register Configuration

Figure 21.4-5 Configuration of the Receive and Transmit Error Counters



# **■** Register Function

Table 21.4-5 Function of Each Bit of the Receive and Transmit Error Counters (RTEC)

| Bit Name            |                                                 | Function                                                                                                                                                                                                                                                                                       |  |  |  |
|---------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| bit15<br>to<br>bit8 | TEC7 to TEC0:<br>Transmit error counter<br>bits | These are transmit error counters. TEC7 to TEC0 values indicate 0 to 7 when the counter value is more than 256, and the subsequent increment is not counted for counter value. In this case, Bus Off is indicated for the node status (NS1 and NS0 of control status register CSR = 11).       |  |  |  |
| bit7<br>to<br>bit0  | REC7 to REC0:<br>Receive error counter<br>bits  | These are receive error counters.  REC7 to REC0 values indicate 0 to 7 when the counter value is more than 256, and the subsequent increment is not counted for counter value. In this case, Error Passive is indicated for the node status (NS1 and NS0 of control status register CSR = 10). |  |  |  |

# 21.4.7 Bit Timing Register (BTR)

Bit timing register (BTR) sets the prescaler and bit timing setting.

### **■** Register Configuration

Figure 21.4-6 Configuration of the Bit Timing Register (BTR)



### **■** Register Function

Table 21.4-6 Function of Each Bit of the Bit Timing Register (BTR)

|                      | Bit Name                                                            | Function                                                                                                                                                                                                                  |
|----------------------|---------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit14<br>to<br>bit12 | TS2.2 to TS2.0:<br>Time segment 2<br>setting bits 2 to 0            | These bits define the number of the time quanta (TQ's) for the time segment 2 (TSEG2). The time segment 2 is equal to the phase buffer segment 2 (PHASE_SEG2) in the CAN specification.                                   |
| bit11<br>to<br>bit8  | TS1.3 to TS1.0:<br>Time segment 1<br>setting bits 3 to 0            | These bits define the number of the time quanta (TQ's) for the time segment 1 (TSEG1).  The time segment 1 is equal to the propagation segment (PROP_SEG) + phase buffer segment 1 (PHASE_SEG1) in the CAN specification. |
| bit7<br>bit6         | RSJ1, RSJ0:<br>Resynchronization<br>jump width setting<br>bits 1, 0 | These bits define the number of the time quanta (TQ's) for the resynchronization jump width.                                                                                                                              |
| bit5<br>to<br>bit0   | PSC5 to PSC0:<br>Prescaler setting bits<br>5 to 0                   | These bits define the time quanta (TQ) of the CAN controller. (see below for details.)                                                                                                                                    |

Note: Please set (CSR: HALT=1) to bit timing register (BTR) after stopping the bus operation. Please release the bus operation stop by writing "0" in the HALT bit of the control status register after the setting of bit timing register (BTR) is ended.

# 21.4.8 Prescaler Setting by Bit Timing Register (BTR)

The setting of bit timing register (BTR) corresponds to the bit time of prescaler in the CAN specification and the CAN controller segment.

### ■ Prescaler Settings

The bit time segments defined in the CAN specification, and the CAN controller are shown in Figure 21.4-7 and Figure 21.4-8 respectively.

Figure 21.4-7 Bit Time Segment in CAN Specification



Figure 21.4-8 Bit Time Segment in CAN Controller



#### **CHAPTER 21 CAN CONTROLLER**

The relationship between PSC = PSC5 to PSC0, TSI = TS1.3 to TS1.0, TS2 = TS2.2 to TS2.0, and RSJ = RSJ1, RSJ0

$$TQ = (PSC + 1) \times CLK$$
 $BT = SYNC\_SEG + TSEG1 + TSEG2$ 
 $= (1 + (TS1 + 1) + (TS2 + 1)) \times TQ$ 
 $= (3 + TS1 + TS2) \times TQ$ 
 $RSJW = (RSJ + 1) \times TQ$ 

RSJ1 and RSJ0 is shown below.

CLK: input clock (CLK)

TQ: time quanta BT: bit time

SYNC\_SEG: synchronous segment

TSEG1 and TSEG2: time segment 1 and 2

resynchronization jump width [(RSJ1 and RSJ0) +1] frequency division

For correct operation, the following conditions should be met.

For 
$$1 \le PSC \le 63$$
:  
 $TSEG1 \ge 2TQ$   
 $TSEG1 \ge RSJW$   
 $TSEG2 \ge 2TQ$   
 $TSEG2 \ge RSJW$   
For  $PSC = 0$ :  
 $TSEG1 \ge 5TQ$   
 $TSEG2 \ge 2TQ$   
 $TSEG2 \ge RSJW$ 

In order to meet the bit timing requirements defined in the CAN specification, additions have to be met, e.g. the propagation delay has to be considered.

# 21.4.9 Message Buffer Valid Register (BVALR)

Message buffer valid register (BVALR) stores the validity of the message buffers or displays their state.

### **■** Register Configuration

Figure 21.4-9 Configuration of the Message Buffer Valid Register (BVALR)



# **■** Register Function

- 0: Message buffer (x) invalid
- 1: Message buffer (x) valid

If the message buffer (x) is set to invalid, it will not transmit or receive messages.

If the buffer is set to invalid during transmission operating, it becomes invalid (BVALx = 0) after the transmission is completed or terminated by an error.

If the buffer is set to invalid during reception operating, it immediately becomes invalid (BVALx = 0). If received messages are stored in a message buffer (x), the message buffer (x) is invalid after storing the messages.

#### **Notes:**

- x indicates a message buffer number (x = 0 to 15).
- When invaliding a message buffer (x) by writing 0 to a bit (BVALx), execution of a bit manipulation instruction is prohibited until the bit is set to 0.
- To invalidate the message buffer (by setting the BVALR: BVAL bit to 0) while the CAN controller is operating for CAN communication (the read value of the CSR: HALT bit is 0 and the CAN controller is operating for CAN bus communication to enable transmission and reception), follow the procedure in "21.13 Precautions when Using CAN Controller".

# 21.4.10 IDE Register (IDER)

This register stores the frame format used by the message buffers (x) during transmission/reception.

### **■** Register Configuration

Figure 21.4-10 Configuration of the IDE Register (IDER)



### **■** Register Function

0: The standard frame format (ID11 bit) is used for the message buffer (x).

1: The extended frame format (ID29 bit) is used for the message buffer (x).

#### **Notes:**

- This register should be set when the message buffer (x) is invalid (BVALx of the message buffer valid register (BVALR) = 0). Setting when the buffer is valid (BVALx = 1) may cause unnecessary received messages to be stored.
- To invalidate the message buffer (by setting the BVALR: BVAL bit to 0) while the CAN controller is operating for CAN communication (the read value of the CSR: HALT bit is 0 and the CAN controller is operating for CAN bus communication to enable transmission and reception), follow the procedure in "21.13 Precautions when Using CAN Controller".

# 21.4.11 Transmission Request Register (TREQR)

Transmission request register (TREQR) stores transmission requests to the message buffers (x) or displays their state.

### **■** Register Configuration

Figure 21.4-11 Configuration of the Transmission Request Register (TREQR)



### **■** Register Function

When 1 is written to TREQx, transmission to the message buffer (x) starts.

If RFWTx of the remote frame receiving wait register (RFWTR)  $^{*1}$  is 0, transmission starts immediately. However, if RFWTx = 1, transmission starts after waiting until a remote frame is received (RRTRx of the remote request receiving register (RRTRR) $^{*1}$  becomes 1). Transmission starts  $^{*2}$  immediately even when RFWTx = 1, if RRTRx is already 1 when 1 is written to TREQx.

- \*1: For RFWTR and TRTRR, see "21.4.12 Transmission RTR Register (TRTRR)" and "21.4.13 Remote Frame Receiving Wait Register (RFWTR)".
- \*2: For cancellation of transmission, see "21.4.14 Transmission Cancel Register (TCANR)" and "21.4.15 Transmission Complete Register (TCR)".

Writing 0 to TREQx is ignored.

0 is read when a Read Modify Write instruction is performed.

If clearing (to 0) at completion of the transmit operation and setting by writing 1 are concurrent, clearing is preferred.

If 1 is written to more than 1 bit, transmission is performed, starting with the lower-numbered message buffer (x).

TREQx is 1 while transmission is pending, and becomes 0 when transmission is completed or canceled.

# 21.4.12 Transmission RTR Register (TRTRR)

This register stores the RTR (Remote Transmission Request) bits for the message buffers (x).

# **■** Register Configuration

Figure 21.4-12 Configuration of the Transmission RTR Register (TRTRR)



# **■** Register Function

0: Transmit data frame.

1: Transmit remote frame.

# 21.4.13 Remote Frame Receiving Wait Register (RFWTR)

Remote frame receiving wait register (RFWTR) sets the conditions for starting transmission when a request for data frame transmission is set (TREQx of the transmission request register (TREQR) is 1 and TRTRx of the transmitting RTR register (TRTRR) is 0).

# **■** Register Configuration

Figure 21.4-13 Configuration of the Remote Frame Receiving Wait Register (RFWTR)



### ■ Register Function

- 0: Transmission starts immediately
- 1: Transmission starts after waiting until remote frame received (RRTRx of remote request receiving register (RRTRR) becomes 1)

#### Notes:

- Transmission starts immediately if RRTRx is already 1 when a request for transmission is set.
- For remote frame transmission, do not set RFWTx to 1.

# 21.4.14 Transmission Cancel Register (TCANR)

This register cancels a pending request for transmission to the message buffer (x).

# **■** Register Configuration

Figure 21.4-14 Configuration of the Transmission Cancel Register (TCANR)



# **■** Register Function

When 1 is written to TCANx, this register cancels a pending request for transmission to the message buffer (x). At completion of cancellation, TREQx of the transmission request register (TREQR) becomes 0.

Writing 0 to TCANx is ignored.

This is a write-only register and its read value is always 0.

# 21.4.15 Transmission Complete Register (TCR)

At completion of transmission by the message buffer (x), the corresponding TCx becomes 1.

If TIEx of the transmission complete interrupt enable register (TIER) is 1, an interrupt occurs.

### **■** Register Configuration

Figure 21.4-15 Configuration of the Transmission Complete Register (TCR)



### **■** Register Function

- $\bullet$  Conditions for TCx = 0
  - Write 0 to TCx.
  - Write 1 to TREQx of the transmission request register (TREQR).

After the completion of transmission, write 0 to TCx to set it to 0. Writing 1 to TCx is ignored.

1 is read when a Read Modify Write instruction is performed.

#### Note:

If setting to 1 by completion of the transmit operation and clearing to 0 by writing occur at the same time, the bit is set to 1.

# 21.4.16 Transmission Interrupt Enable Register (TIER)

This register enables or disables the transmission interrupt by the message buffer (x). The transmission interrupt is generated at transmission completion (when TCx of the transmission complete register (TCR) is 1).

### **■** Register Configuration

Figure 21.4-16 Configuration of the Transmission Interrupt Enable Register (TIER)



# **■** Register Function

0: Transmission interrupt disabled.

1: Transmission interrupt enabled.

# 21.4.17 Reception Complete Register (RCR)

At completion of storing received message in the message buffer (x), RCx becomes 1. If RIEx of the reception complete interrupt enable register (RIER) is 1, an interrupt occurs.

### **■** Register Configuration

Figure 21.4-17 Configuration of the Reception Complete Register (RCR)



# **■** Register Function

### • Conditions for RCx = 0

Write 0 to RCx.

After completion of handling received message, write 0 to RCx to set it to 0. Writing 1 to RCx is ignored. 1 is read when a Read Modify Write instruction is performed.

#### Note:

If setting to 1 by completion of the receive operation and clearing to 0 by writing occur at the same time, the bit is set to 1.

# 21.4.18 Remote Request Receiving Register (RRTRR)

After a remote frame is stored in the message buffer (x), RRTRx becomes 1 (at the same time as RCx setting to 1).

### **■** Register Configuration

Figure 21.4-18 Configuration of the Remote Request Receiving Register (RRTRR)



# **■** Register Function

- Conditions for RRTRx = 0
  - Write 0 to RRTRx.
  - After a received data frame is stored in the message buffer (x) (at the same time as RCx setting to 1).
  - Transmission by the message buffer (x) is completed (TCx of the transmission complete register (TCR) is 1).

Writing 1 to RRTRx is ignored.

1 is read when a Read Modify Write instruction is performed.

#### Note:

If setting to 1 by completion of the receive operation and clearing to 0 by writing occur at the same time, the bit is set to 1.

# 21.4.19 Receive Overrun Register (ROVRR)

If RCx of the reception complete register (RCR) is 1 when completing storing of a received message in the message buffer (x), ROVRx becomes 1, indicating that reception has overrun.

### **■** Register Configuration

Figure 21.4-19 Configuration of the Receive overrun Register (ROVRR)



# **■** Register Function

Writing 0 to ROVRx results in ROVRx = 0. Writing 1 to ROVRx is ignored. After checking that reception has overrun, write 0 to ROVRx to set it to 0.

1 is read when a Read-Modify-Write instruction is performed.

#### Note:

If setting to 1 by completion of the receive operation and clearing to 0 by writing occur at the same time, the bit is set to 1.

# 21.4.20 Reception Interrupt Enable Register (RIER)

Reception interrupt enable register (RIER) enables or disables the reception interrupt by the message buffer (x).

The reception interrupt is generated at reception completion (when RCx of the reception completion register (RCR) is 1).

### **■** Register Configuration

Figure 21.4-20 Configuration of the Reception Interrupt Enable Register (RIER)



# **■** Register Function

- 0: Reception interrupt disabled.
- 1: Reception interrupt enabled.

# 21.4.21 Acceptance Mask Select Register (AMSR)

This register selects masks (acceptance mask) for comparison between the received message ID's and the message buffer ID.

# **■** Register Configuration

Figure 21.4-21 Configuration of the Acceptance Mask Select Register (AMSR)



# **■** Register Function

**Table 21.4-7 Selection of Acceptance Mask** 

| AMSx.1 | AMSx.0 | Acceptance Mask                   |
|--------|--------|-----------------------------------|
| 0      | 0      | Full-bit comparison               |
| 0      | 1      | Full-bit mask                     |
| 1      | 0      | Acceptance mask register 0 (AMR0) |
| 1      | 1      | Acceptance mask register 1 (AMR1) |

#### **Notes:**

- AMSx.1 and AMSx.0 should be set when the message buffer (x) is invalid (BVALx of the message buffer valid register (BVALR) is 0). Setting when the buffer is valid (BVALx = 1) may cause unnecessary received messages to be stored.
- To invalidate the message buffer (by setting the BVALR: BVAL bit to 0) while the CAN controller is operating for CAN communication (the read value of the CSR: HALT bit is 0 and the CAN controller is operating for CAN bus communication to enable transmission and reception), follow the procedure in "21.13 Precautions when Using CAN Controller".

# 21.4.22 Acceptance Mask Registers 0 and 1 (AMR0 and AMR1)

There are two acceptance mask registers, which are available either in the standard frame format or extended frame format.

AM28 to AM18 (11 bits) are used for acceptance masks in the standard frame format and AM28 to AM0 (29 bits) are used for acceptance masks in the extended format.

### **■** Register Configuration

Figure 21.4-22 Configuration of the Acceptance Mask Register 0 (AMR0)



Address bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 AMR11(Byte0) AM27 CAN1: 007D18H AM28 AM26 AM25 AM24 AM23 AM22 AM21 Reset value XXXXXXXXB R/W R/W R/W R/W R/W R/W R/W R/W bit15 Address bit14 bit13 bit12 bit11 bit10 bit9 bit8 AMR11(Byte1) CAN1: 007D19н AM20 AM19 AM18 AM17 AM16 AM15 AM14 AM13 Reset value XXXXXXXXB R/W R/W R/W R/W R/W R/W R/W R/W Address bit7 bit5 bit6 bit4 bit3 bit2 bit1 bit0 AMR11(Byte2) CAN1: 007D1Aн AM12 AM11 AM10 AM9 AM8 AM7 AM6 AM5 Reset value XXXXXXXXB R/W R/W R/W R/W R/W R/W R/W R/W Address bit15 bit14 bit13 bit12 bit11 bit10 bit9 bit8 AMR11(Byte3) CAN1: 007D1Вн AM4 AM3 AM2 AM1 AM0 Reset value XXXXXXXXB R/W R/W R/W R/W R/W : Read/Write R/W : Undefined Χ : Unused : Used bit in typical frame format

Figure 21.4-23 Configuration of the Acceptance Mask Register 1 (AMR1)

#### **■** Register Function

#### 0: Compare

Compare the bit (be set to "0") of the acceptance code (ID register IDRx for comparing with the received message ID) corresponding to this bit with the bit of the received message ID. If there is no match, no message is received.

#### 1: Mask

Mask the bit of the acceptance code ID register (IDRx) corresponding to this bit. No comparison is made with the bit of the received message ID.

#### **Notes:**

- AMR0 and AMR1 should be set when all the message buffers (x) selecting AMR0 and AMR1 are invalid (BVALx of the message buffer valid register (BVALR) is 0). Setting when the buffers are valid (BVALx = 1) may cause unnecessary received messages to be stored.
- To invalidate the message buffer (by setting the BVALR: BVAL bit to 0) while the CAN controller is operating for CAN communication (the read value of the CSR: HALT bit is 0 and the CAN controller is operating for CAN bus communication to enable transmission and reception), follow the procedure in "21.13 Precautions when Using CAN Controller".

# 21.4.23 Message Buffers

There are 16 message buffers. Message buffer x (x = 0 to 15) consists of an ID register (IDRx), DLC register (DLCRx), and data register (DTRx).

# ■ Message Buffers

- Register Configuration
  - ID register x (x = 0 to 15) (IDRx)

This register is a ID register of the message buffer. This register memorizes receipt code setting, transmission message ID setting, and reception ID.

• DLC register x (x = 0 to 15) (DLCRx)

This register stores the DLC of the message buffer. This register sets the data length of the message when a data frame and a remote frame are transmitted and the data length of the message when a data frame or a remote frame is received.

• Data register x (x = 0 to 15) (DTRx)

This register is a data register of the message buffer. This register memorizes the setting or the reception message data of the transmission message data.

- The message buffer (x) is used both for transmission and reception.
- The lower-numbered message buffers are assigned higher priority.
  - At transmission, when a request for transmission is made to more than 1 message buffer, transmission is performed, starting with the lowest-numbered message buffer (See "21.5 Transmission of CAN Controller").
  - At reception, when the received message ID passes through the acceptance filter (mechanism for comparing the acceptance-masked ID of received message and message buffer) of more than 1 message buffer, the received message is stored in the lowest-numbered message buffer (See "21.6 Reception of CAN Controller").

#### Message buffer that can be used as multi level message buffer

When the same receipt filter is set in 1 or more message buffers, the message buffer can be used as a multi level message buffer.

As a result, the reserve to the reception time is given. (See "21.10" Procedure for Reception by Message Buffer (x)").

#### **Notes:**

- A write operation to message buffers and general-purpose RAM areas should be performed in words to even addresses only. A write operation in bytes causes undefined data to be written to the upper byte at writing to the lower byte. Writing to the upper byte is ignored.
- When the BVALx bit of the message buffer valid register (BVALR) is 0 (Invalid), the message buffers x (IDRx, DLCRx, and DTRx) can be used as general-purpose RAM.
  - During the receive/transmit operation of the CAN controller, the CAN Controller write/read to/from the message buffers. If the CPU tries to write/read to/from the message buffers in this period, the CPU has to wait a maximum time of 64 machine cycles.

This is also true for the general-purpose RAM (Address  $007A00_H$  to  $007A1F_H$ ,  $007C00_H$  to  $007C1F_H$ ,  $007E00_H$  to  $007E1F_H$ ).

# 21.4.24 ID Register x (x = 0 to 15) (IDRx)

This register is the ID register for message buffer (x).

# **■** Register Configuration

Figure 21.4-24 Configuration of the ID Registers (IDRx)



### **■** Register Function

When using the message buffer (x) in the standard frame format (IDEx of the IDE register (IDER) = 0), use 11 bits of ID28 to ID18. When using the buffer in the extended frame format (IDEx = 1), use 29 bits of ID28 to ID0.

ID28 to ID0 have the following functions;

- Set acceptance code (ID for comparing with the received message ID).
- Set transmitted message ID.

Note: In the standard frame format, setting 1s to all bits of ID28 to ID22 is prohibited).

• Store the received message ID.

Note: All received message ID bits are stored (even if bits are masked). In the standard frame format, ID17 to ID0 stores image of old message left in the receive shift register.

#### **Notes:**

- A write operation to this register should be performed in words. A write operation in bytes causes undefined data to be written to the upper byte at writing to the lower byte. Writing to the upper byte is ignored.
- This register should be set when the message buffer (x) is invalid (BVALx of the message buffer valid register (BVALR) is 0). Setting when the buffer is valid (BVALx = 1) may cause unnecessary received messages to be stored.
- To invalidate the message buffer (by setting the BVALR: BVAL bit to 0) while the CAN controller is operating for CAN communication (the read value of the CSR: HALT bit is 0 and the CAN controller is operating for CAN bus communication to enable transmission and reception), follow the procedure in "21.13 Precautions when Using CAN Controller".

# 21.4.25 DLC Register x (x = 0 to 15) (DLCRx)

This register is the DLC register for message buffer (x).

# **■** Register Configuration

Figure 21.4-25 Configuration of the DLC Registers (DLCRx)



# **■** Register Function

#### Transmission

- Set the data length (byte count) of a transmitted message when a data frame is transmitted (TRTRx of the transmitting RTR register (TRTRR) is 0).
- Set the data length (byte count) of a requested message when a remote frame is transmitted (TRTRx = 1).

#### Note:

Setting other than  $0000_B$  to  $1000_B$  (0 to 8 bytes) is prohibited.

#### Reception

- Store the data length (byte count) of a received message when a data frame is received (RRTRx of the remote frame request receiving register (RRTRR) is 0).
- Store the data length (byte count) of a requested message when a remote frame is received (RRTRx = 1).

#### Note:

A write operation to this register should be performed in words. A write operation in bytes causes undefined data to be written to the upper byte at writing to the lower byte. Writing to the upper byte is ignored.

# 21.4.26 Data Register x (x = 0 to 15) (DTRx)

This register is the data register for message buffer (x). This register is used only in transmitting and receiving a data frame but not in transmitting and receiving a remote frame.

# **■** Register Configuration

Figure 21.4-26 Configuration of the Data Registers (DTRx)

| Address                        |                        | bit7  | bit6  | bit5  | bit4  | bit3  | bit2  | bit1 | bit0 | DTRx1(Byte0)           |
|--------------------------------|------------------------|-------|-------|-------|-------|-------|-------|------|------|------------------------|
| CAN1:                          | 007С80н + 8 × х        | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ' XXXXXXXB             |
| Address                        |                        | bit15 | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 | DTRx1(Byte1)           |
| CAN1:                          | 007С81н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ¹ XXXXXXXB             |
| Address                        |                        | bit7  | bit6  | bit5  | bit4  | bit3  | bit2  | bit1 | bit0 | DTRx1(Byte2)           |
| CAN1:                          | 007С82н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ¹ XXXXXXXXB            |
| Address                        |                        | bit15 | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 | DTRx1(Byte3)           |
| CAN1:                          | 007С83н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                | •                      | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ' XXXXXXXXB            |
| Address                        |                        | bit7  | bit6  | bit5  | bit4  | bit3  | bit2  | bit1 | bit0 | DTRx1(Byte4)           |
| CAN1:                          | 007С84н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ' XXXXXXXB             |
| Address                        |                        | bit15 | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 | DTRx1(Byte5)           |
| CAN1:                          | 007С85н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ¹ XXXXXXXXB            |
| Address                        |                        | bit7  | bit6  | bit5  | bit4  | bit3  | bit2  | bit1 | bit0 | DTRx1(Byte6)           |
| CAN1:                          | 007С86н <b>+</b> 8 × х | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                | •                      | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | ¹ XXXXXXXB             |
| Address                        |                        | bit15 | bit14 | bit13 | bit12 | bit11 | bit10 | bit9 | bit8 | DTRx1(Byte7)           |
| CAN1:                          | 007С87н + 8 × х        | D7    | D6    | D5    | D4    | D3    | D2    | D1   | D0   | Reset value            |
|                                |                        | R/W   | R/W   | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | <sup>1</sup> XXXXXXXXB |
| R/W : Rea<br>X : Un<br>– : Unu | defined                |       |       |       |       |       |       |      |      | x = 0,, 15             |

# **■** Register Function

Sets transmitted message data (any of 0 to 8 bytes).

Data is transmitted in the order of BYTE0, BYTE1, ..., BYTE7, starting with the MSB.

Stores received message data.

Data is stored in the order of BYTE0, BYTE1, ..., BYTE7, starting with the MSB.

Even if the received message data is less than 8 bytes, the remaining bytes of the data register (DTRx), to which data are stored, are undefined.

#### Note:

A write operation to this register should be performed in words. A write operation in bytes causes undefined data to be written to the upper byte at writing to the lower byte. Writing to the upper byte is ignored.

# 21.5 Transmission of CAN Controller

When 1 is written to TREQx of the transmission request register (TREQR), transmission by the message buffer (x) starts. At this time, TREQx becomes 1 and TCx of the transmission complete register (TCR) becomes 0.

### ■ Starting Transmission of CAN Controller

If RFWTx of the remote frame receiving wait register (RFWTR) is 0, transmission starts immediately. If RFWTx is 1, transmission starts after waiting until a remote frame is received (RRTRx of the remote request receiving register (RRTRR) becomes 1).

If a request for transmission is made to more than 1 message buffer (more than one TREQx is 1), transmission is performed, starting with the lowest-numbered message buffer.

Message transmission to the CAN bus (by the transmit output pin TX) starts when the bus is idle.

If TRTRx of the transmission RTR register (TRTRR) is 0, a data frame is transmitted. If TRTRx is 1, a remote frame is transmitted.

If the message buffer competes with other CAN controllers on the CAN bus for transmission and arbitration fails, or if an error occurs during transmission, the message buffer waits until the bus is idle and repeats retransmission until it is successful.

### **■** Canceling Transmission Request from CAN Controller

Canceling by transmission cancel register (TCANR)

A transmission request for message buffer (x) having not executed transmission during transmission pending can be canceled by writing 1 to TCANx of the transmission cancel register (TCANR). At completion of cancellation, TREQx becomes 0.

#### Canceling by storing received message

The message buffer (x) having not executed transmission despite transmission request also performs reception.

If the message buffer (x) has not executed transmission despite a request for transmission of a data frame (TRTRx = 0 or TREQx = 1), the transmission request is canceled after storing received data frames passing through the acceptance filter (TREQx = 0).

#### Note:

A transmission request is not canceled by storing remote frames (TREQx = 1 remains unchanged).

If the message buffer (x) has not executed transmission despite a request for transmission of a remote frame (TRTRx = 1 or TREQx = 1), the transmission request is canceled after storing received remote frames passing through the acceptance filter (TREQx = 0).

#### Note:

The transmission request is canceled by storing either data frames or remote frames.

### **■** Completing Transmission of CAN Controller

When transmission is successful, RRTRx becomes 0, TREQx becomes 0, and TCx of the transmission complete register (TCR) becomes 1. If the transmission complete interrupt is enabled (TIEx of the transmission complete interrupt enable register (TIER) is 1), an interrupt occurs.

#### **■** Transmission Flowchart of CAN Controller



Figure 21.5-1 Transmission Flowchart of the CAN Controller

# 21.6 Reception of CAN Controller

Reception starts when the start of data frame or remote frame (SOF) is detected on the CAN bus.

#### ■ Acceptance Filtering

The received message in the standard frame format is compared with the message buffer (x) set in the standard frame format (IDEx of the IDE register (IDER) is 0). The received message in the extended frame format is compared with the message buffer (x) set (IDEx is 1) in the extended frame format.

If all the bits set to Compare by the acceptance mask agree after comparison between the received message ID and acceptance code (ID register (IDRx) for comparing with the received message ID), the received message passes to the acceptance filter of the message buffer (x).

#### ■ Storing Received Message

When the receive operation is successful, received messages are stored in a message buffer x including IDs passed through the acceptance filter.

When receiving data frames, received messages are stored in the ID register (IDRx), DLC register (DLCRx), and data register (DTRx).

Even if received message data is less than 8 bytes, some data is stored in the remaining bytes of the DTRx and its value is undefined.

When receiving remote frames, received messages are stored only in the IDRx and DLCRx, and the DTRx remains unchanged.

If there is more than 1 message buffer including IDs passed through the acceptance filter, the message buffer x in which received messages are to be stored is determined according to the following rules.

- The order of priority of the message buffer x (x = 0 to 15) rises as its number lower; in other words, message buffer 0 is given the highest and the message buffer 15 is given the lowest priority.
- Basically, message buffers with the RCx bit of 0 in the receive completion register (RCR) are preferred in storing received messages.
- If the bits of the acceptance mask select register (AMSR) are set to All Bits Compare (for message buffers with the AMSx.1 and AMSx.0 bits set to 00<sub>B</sub>), received messages are stored irrespective of the value of the RCx bit of the RCR.
- If there are message buffers with the RCx bit of the RCR set to 0, or with the bits of the AMSR set to All Bits Compare, received messages are stored in the lowest-number (highest-priority) message buffer x.
- If there are no message buffers above-mentioned, received messages are stored in a lower-number message buffer x.
- Message buffers should be arranged in ascending numeric order. The lowest message buffers should be
  with All Bits Compare, then AMR0 or AMR1 masks. And The highest message buffers should be with
  All Bits Mask.

Figure 21.6-1 shows a flowchart for determining the message buffer (x) where received messages are to be stored. It is recommended that message buffers be arranged in the following order: message buffers in which each AMSR bit is set to All Bits Compare, message buffers using AMR0 or AMR1, and message buffers in which each AMSR bit is set to All Bits Mask.

Are message buffers with RCx set to 0 or with AMSx.1 and AMSx.0 set to 00<sub>B</sub> found?

YES

Select the lowest-numbered message buffer from above message buffer.

End

NO

Select the lowest-numbered message buffer.

Figure 21.6-1 Flowchart Determining Message Buffer (x) where Received Messages Stored

#### **■** Receive Overrun

When a message is stored in the message buffer with the corresponding RCx being already set to 1, it will results in receive overrun. In this case, the corresponding ROVRx bit in the receive overrun register ROVRR is set to 1.

#### ■ Processing for Reception of Data Frame and Remote Frame

Processing for reception of data frame

RRTRx of the remote request receiving register (RRTRR) becomes 0.

TREQx of the transmission request register (TREQR) becomes 0 (immediately before storing the received message). A transmission request for message buffer (x) having not executed transmission will be canceled.

#### Note:

A request for transmission of either a data frame or remote frame is canceled.

#### Processing for reception of remote frame

RRTRx becomes 1.

If TRTRx of the transmitting RTR register (TRTRR) is 1, TREQx becomes 0. As a result, the request for transmitting remote frame to message buffer having not executed transmission will be canceled.

#### **Notes:**

- A request for data frame transmission is not canceled.
- For cancellation of a transmission request, see "21.5 Transmission of CAN Controller".

# **■** Completing Reception

RCx of the reception complete register (RCR) becomes 1 after storing the received message.

If a reception interrupt is enabled (RIEx of the reception interrupt enable register (RIER) is 1), an interrupt occurs.

#### Note:

This CAN controller will not receive any messages transmitted by itself.

# 21.7 Reception Flowchart of CAN Controller

Figure 21.7-1 shows a reception flowchart of the CAN controller.

#### ■ Reception Flowchart of the CAN Controller



#### 21.8 How to Use CAN Controller

#### The following settings are required to use the CAN controller;

- Bit timing
- Frame format
- ID
- Acceptance filter
- Low-power consumption mode

#### **■** Setting Bit Timing

The bit timing register (BTR) should be set during bus operation stop (when the bus operation stop bit (HALT) of the control status register (CSR) is 1).

After the setting completion, write 0 to HALT to cancel bus operation stop.

#### ■ Setting Frame Format

Set the frame format used by the message buffer (x). When using the standard frame format, set IDEx of the IDE register (IDER) to 0. When using the extended frame format, set IDEx to 1.

This setting should be made when the message buffer (x) is invalid (BVALx) of the message buffer valid register (BVALR) is 0). Setting when the buffer is valid (BVALx = 1) may cause unnecessary received messages to be stored.

## ■ Setting ID

Set the message buffer (x) ID to ID28 to ID0 of ID register (IDRx). The message buffer (x) ID need not be set to ID11 to ID0 in the standard frame format. The message buffer (x) ID is used as a transmission message at transmission and is used as an acceptance code at reception.

This setting should be made when the message buffer (x) is invalid (BVALx of the message buffer valid register (BVALR) is 0). Setting when the buffer is valid (BVALx = 1) may cause unnecessary received messages to be stored.

#### ■ Setting Acceptance Filter

The acceptance filter of the message buffer (x) is set by an acceptance code and acceptance mask set. It should be set when the acceptance message buffer (x) is invalid (BVALx) of the message buffer enable register (BVALR) is 0). Setting when the buffer is valid (BVALx) may cause unnecessary received messages to be stored.

Set the acceptance mask used in each message buffer (x) by the acceptance mask select register (AMSR). The acceptance mask registers (AMR0 and AMR1) should also be set if used (For the setting details, see "21.4.21 Acceptance Mask Select Register (AMSR)" and "21.4.22 Acceptance Mask Registers 0 and 1 (AMR0 and AMR1)").

The acceptance mask should be set so that a transmission request may not be canceled when unnecessary received messages are stored. For example, it should be set to a full-bit comparison if only one specific ID is used for the transmission.

# ■ Setting Low-power Consumption Mode

To set the  $F^2MC$ -16LX in a low-power consumption mode (Stop and Timebase timer), write 1 to the bus operation stop bit (HALT) of the control status register (CSR), and then check that the bus operation has stopped (HALT = 1).

# 21.9 Procedure for Transmission by Message Buffer (x)

After setting the bit timing, frame format, ID, and acceptance filter, set BVALx to 1 to activate the message buffer (x).

#### ■ Procedure for Transmission by Message Buffer (x)

#### Setting transmit data length code

Set the transmit data length code (byte count) to DLC3 to DLC0 of the DLC register (DLCRx).

For data frame transmission (when TRTRx of the transmission RTR register (TRTRR) is 0), set the data length of the transmitted message.

For remote frame transmission (when TRTRx = 1), set the data length (byte count) of the requested message.

#### Note:

Setting other than  $0000_B$  to  $1000_B$  (0 to 8 bytes) is prohibited.

#### Setting transmit data (only for transmission of data frame)

For data frame transmission (when TRTRx of the transmission register (TRTRR) is 0), set data as the count of byte transmitted in the data register (DTRx).

#### Note:

Transmit data should be rewritten while the TREQx bit of the transmission request register (TREQR) set to 0. There is no need for setting the BVALx bit of the message buffer valid register (BVALR) to 0. Setting the BVALx bit to 0 may cause incoming remote frame to be lost.

#### Setting transmission RTR register

For data frame transmission, set TRTRx of the transmission RTR register (TRTRR) to 0.

For remote frame transmission, set TRTRx to 1.

#### Setting conditions for starting transmission (only for transmission of data frame)

Set RFWTx of the remote frame receiving wait register (RFWTR) to 0 to start transmission immediately after a request for data frame transmission is set (TREQx of the transmission request register (TREQR) is 1 and TRTRx of the transmission RTR register (TRTRR) is 0).

Set RFWTx to 1 to start transmission after waiting until a remote frame is received (RRTRx of the remote request receiving register (RRTRR) becomes 1) after a request for data frame transmission is set (TREQx = 1 and TRTRx = 0).

#### Note:

Remote frame transmission can not be made, if RFWTx is set to 1.

#### Setting transmission complete interrupt

When generating a transmission complete interrupt, set TIEx of the transmission complete interrupt enable register (TIER) to 1.

When not generating a transmission complete interrupt, set TIEx to 0.

#### Setting transmission request

For a transmission request, set TREQx of the transmission request register (TREQR) to 1.

#### Canceling transmission request

When canceling a pending request for transmission to the message buffer (x), write 1 to TCANx of the transmission cancel register (TCANR).

Check TREQx. For TREQx = 0, transmission cancellation is terminated or transmission is completed. Check TCx of the transmission complete register (TCR). For TCx = 0, transmission cancellation is terminated. For TCx = 1, transmission is completed.

#### Processing for completion of transmission

If transmission is successful, TCx of the transmission complete register (TCR) becomes 1.

If the transmission complete interrupt is enabled (TIEx of the transmission complete interrupt enable register (TIER) is 1), an interrupt occurs.

After checking the transmission completion, write 0 to TCx to set it to 0. This cancels the transmission complete interrupt.

In the following cases, the pending transmission request is canceled by receiving and storing a message.

- · Cancel the request for data frame transmission by reception of data frame
- Cancel the request for remote frame transmission by reception of data frame
- Cancel the request for remote frame transmission by reception of remote frame

Request for data frame transmission is not canceled by receiving and storing a remote frame. ID and DLC, however, are changed by the ID and DLC of the received remote frame. Note that the ID and DLC of data frame to be transmitted become the value of received remote frame.

# 21.10 Procedure for Reception by Message Buffer (x)

After setting the bit timing, frame format, ID, and acceptance filter, make the settings described below.

#### ■ Procedure for Reception by Message Buffer (x)

#### Setting reception interrupt

To enable reception interrupt, set RIEx of the reception interrupt enable register (RIER) to 1.

To disable reception interrupt, set RIEx to 0.

#### Starting reception

When starting reception after setting, set BVALx of the message buffer valid register (BVALR) to 1 to make the message buffer (x) valid.

#### Processing for reception completion

If reception is successful after passing to the acceptance filter, the received message is stored in the message buffer (x) and RCx of the reception complete register (RCR) becomes 1. For data frame reception, RRTRx of the remote request receiving register (RRTRR) becomes 0. For remote frame reception, RRTRx becomes 1.

If a reception interrupt is enabled (RIEx of the reception interrupt enable register (RIER) is 1), an interrupt occurs.

After checking the reception completion (RCx = 1), process the received message.

After completion of processing the received message, check ROVRx of the reception overrun register (ROVRR).

If ROVRx = 0, the processed received message is valid. Write 0 to RCRx to set it to 0 (the reception complete interrupt is also canceled) to terminate reception.

If ROVRx = 1, a reception overrun occurred and the next message may have overwritten the processed message. In this case, received messages should be processed again after setting the ROVRx bit to 0 by writing 0 to it.

Figure 21.10-1 shows an example of receive interrupt handling.



Figure 21.10-1 Example of Receive Interrupt Handling

# 21.11 Setting Configuration of Multi-level Message Buffer

If the receptions are performed frequently, or if several different ID's of messages are received, in other words, if there is insufficient time for handling messages, more than 1 message buffer can be combined into a multi-level message buffer to provide allowance for processing time of the received message by CPU.

#### ■ Setting Configuration of Multi-level Message Buffer

To provide a multi-level message buffer, the same acceptance filter must be set in the combined message buffers.

If the bits of the acceptance mask select register (AMSR) are set to All Bits Compare ((AMSx.1, AMSx.0) = (0, 0)), multi-level message configuration of message buffers is not allowed. This is because All Bits Compare causes received messages to be stored irrespective of the value of the RCx bit of the receive completion register (RCR), so received messages are always stored in lower-numbered (higher-priority) message buffers even if All Bits Compare and identical acceptance code (ID register (IDRx)) are specified for more than 1 message buffer. Therefore, All Bits Compare and identical acceptance code should not be specified for more than 1 message buffer.

Figure 21.11-1 shows operational examples of multi-level message buffers.



Figure 21.11-1 Examples of Operation of Multi-level Message Buffer

#### Note:

Four messages are received with the same acceptance filter set in message buffers 13, 14 and 15.

# 21.12 Setting the CAN Direct Mode Register

To operate CAN normally, this register must be set correctly.

#### ■ CAN Direct Mode Register (CDMR) (Only MB90V340)

Figure 21.12-1 Configuration of the CAN Direct Mode Register (CDMR) (Only MB90V340)



Table 21.12-1 Function of CAN Direct Mode Register (CDMR)

| Bit Name   |                | Function                                                                                                                                   |  |  |
|------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit 7 to 1 | Undefined bits | -                                                                                                                                          |  |  |
| bit 0      | DIRECT         | If the clock modulation is set (initial state), the bit should be set "0".  If the clock modulation is not set, the bit should be set "1". |  |  |

#### Note:

MB90360 does not have the clock modulation function.

So, at using CAN controller, the DIRECT bit of the register must be set "1".

# 21.13 Precautions when Using CAN Controller

#### Use of the CAN Controller requires the following cautions.

#### ■ Caution for Disabling Message Buffers by BVAL Bits

The use of BVAL bits may affect malfunction of CAN Controller when messages buffers are set disabled while CAN Controller is participating in CAN communication. This section shows the work around of this malfunction.

#### Condition

When following 2 conditions occur at the same time, the CAN Controller will not perform to transmit messages normally.

- CAN Controller is participating in the CAN communication. (i.e. The read value of the CSR: HALT bit is 0 and CAN Controller is ready to transmit messages)
- Message buffers are read when BVAL bits disable the message buffers.

#### Work around

#### Operation for suppressing transmission request

Do not use BVAL bit for suppressing transmission request, use TCAN bit instead of it.

#### Operation for composing transmission message

For composing a transmission message, it is necessary to disable the message buffer by BVAL bit to change contents of ID and IDE registers. In this case, BVAL bit should reset (BVAL=0) after checking if TREQ bit is 0 or after completion of the previous message transmission (TC=1).

In case a buffer needs to be disabled, ensure that no transmission request is pending (if it was requested before). Therefore, do not reset BVALx-Bit before testing, if a transmission is ongoing;

- a) Cancel the transmission request (TCANx=1;), if necessary
- b) and wait for the transmission completion (while (TREQx==1);) by polling or interrupt.

Only after that the transmission buffer can be disabled (BVALx=0;).

#### Note:

For case a), if transmission of that buffer has already started, canceling the request is ignored and disabling the buffer is delayed until the end of the transmission.

# **■ Setting of CAN Direct Mode**

MB90360 does not provide the clock modulation function. For this reason, ensure that the DIRECT bit of the CAN direct mode register (CDMR) is set to 1 when CAN is used.

Note that the CAN controller will not normally operate without correct setting of the DIRECT bit.

# CHAPTER 22

# ADDRESS MATCH DETECTION FUNCTION

This chapter explains the address match detection function and its operation.

- 22.1 Overview of Address Match Detection Function
- 22.2 Block Diagram of Address Match Detection Function
- 22.3 Configuration of Address Match Detection Function
- 22.4 Explanation of Operation of Address Match Detection Function
- 22.5 Program Example of Address Match Detection Function

#### 22.1 Overview of Address Match Detection Function

If the address of the instruction to be processed next to the instruction currently processed by the program matches the address set in the detect address setting registers, the address match detection function forcibly replaces the next instruction to be processed by the program with the INT9 instruction to branch to the interrupt processing program. Since the address match detection function can use the INT9 interrupt for instruction processing, the program can be corrected by patch processing.

#### ■ Overview of Address Match Detection Function

- The address of the instruction to be processed next to the instruction currently processed by the program is always held in the address latch through the internal data bus. The address match detection function always compares the value of the address held in the address latch with that of the address set in the detect address setting registers. When these compared values match, the next instruction to be processed by the CPU is forcibly replaced by the INT9 instruction, and the interrupt processing program is executed.
- There are six detect address setting registers (PADR0 to PADR5), each of which has an interrupt enable bit. The generation of an interrupt due to a match between the address held in the address latch and the address set in the detect address setting registers can be enabled or disabled for each register.

# 22.2 Block Diagram of Address Match Detection Function

The address match detection module consists of the following blocks:

- Address latch
- Address detection control register (PACSR0/PACSR1)
- Detect address setting registers (PADR0 to PADR5)

#### ■ Block Diagram of Address Match Detection Function

Figure 22.2-1 shows the block diagram of the address match detection function.

Address latch Comparator INT9 instruction (INT9 instruction Detection address setting register 0 generation) PADR0 (24 bits) Detection address setting register 1 PADR1 (24 bits) nternal data bus Detection address setting register 5 PADR5 (24 bits) PACSR0 Reserved Reserved Reserved Reserved Reserved AD2E AD1E AD0E Address detection control register 0 (PACSR0) Reserved Reserved AD5E Reserved Reserved Reserved AD4E AD3E Address detection control register 1 (PACSR1) Reserved: Always setting to 0.

Figure 22.2-1 Block Diagram of the Address Match Detection Function

#### Address latch

The address latch stores the value of the address output to the internal data bus.

Address detection control register (PACSR0/PACSR1)

The address detection control register enables or disables output of an interrupt at an address match.

Detect address setting registers (PADR0 to PADR5)

The detect address setting registers set the address that is compared with the value of the address latch.

# 22.3 Configuration of Address Match Detection Function

This section lists and details the registers used by the address match detection function.

# ■ List of Registers and Reset Values of Address Match Detection Function

Figure 22.3-1 List of Registers and Reset Values of Address Match Detection Function

| bit   7   6   5   4   3   2   1   0   0   0   0   0   0   0   0   0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Figure 22.3-1 List of Registers and Res                                        | SEL Vai | ues of A         | uuies | 5 IVIAL  | יוו ספו | CCLIOI  | ı ı unc | LIOII |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|---------|------------------|-------|----------|---------|---------|---------|-------|
| Address detection control register 1(PACSR1)  Detection address setting register 0(PADR0): Middle  Detection address setting register 0(PADR0): Middle  Detection address setting register 0(PADR0): Middle  Detection address setting register 1(PADR1): Low  Detection address setting register 1(PADR1): Low  Detection address setting register 1(PADR1): Middle  Detection address setting register 1(PADR1): Middle  Detection address setting register 1(PADR1): Middle  Detection address setting register 2(PADR2): Low  Detection address setting register 2(PADR2): Low  Detection address setting register 2(PADR2): Middle  Detection address setting register 2(PADR2): Middle  Detection address setting register 3(PADR3): Low  Detection address setting register 4(PADR4): Middle  Detection address setting register 4(PADR4): Middle  Detection address setting register 4(PADR4): Middle  Detection address setting register 5(PADR5): Middle                                                                                                                                                                                                                                                                                                                                           |                                                                                |         | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Detection address setting register 0(PADR0); Low   Detection address setting register 0(PADR0); Middle   Detection address setting register 0(PADR0); High   Detection address setting register 1(PADR1); Low   Detection address setting register 1(PADR1); High   Detection address setting register 1(PADR1); High   Detection address setting register 1(PADR1); High   Detection address setting register 2(PADR2); Middle   Detection address setting register 2(PADR2); Middle   Detection address setting register 2(PADR2); Middle   Detection address setting register 3(PADR3); Low   Detection address setting register 3(PADR3); Low   Detection address setting register 3(PADR3); Middle   Detection address setting register 4(PADR4); High   Detection address setting register 4(PADR4); High   Detection address setting register 4(PADR4); High   Detection address setting register 5(PADR5); Middle   Detection address    | Address detection control register 0(PACSR0)                                   | 0       | 0                | 0     | 0        | 0       | 0       | 0       | 0     |
| Detection address setting register 0(PADR0): Low   Detection address setting register 0(PADR0): Middle   Detection address setting register 1(PADR1): High   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): High   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Middle   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection address setting registe   |                                                                                | bit 15  | 5 14             | 13    | 12       | 11      | 10      | 9       | 8     |
| Detection address setting register 0(PADR0): Middle   Detection address setting register 0(PADR0): Middle   Detection address setting register 1(PADR1): Low   Detection address setting register 1(PADR1): High   Detection address setting register 1(PADR1): High   Detection address setting register 2(PADR2): Middle   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Middle   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detecti   | Address detection control register 1(PACSR1)                                   |         |                  | 0     | 0        | 0       | 0       | 0       | 0     |
| Detection address setting register 0(PADR0): Middle   Setting register 0(PADR0): High   Detection address setting register 1(PADR1): Low   Detection address setting register 1(PADR1): Middle   Detection address setting register 1(PADR1): Middle   Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Middle   Detection address setting register 3(PADR3): Middle   Detection address setting register 4(PADR4): Middle   Detection address setting register 4(PADR4): Middle   Detection address setting register 4(PADR4): Middle   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection add   | Detection address actting register (/DADDO): Low                               | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Detection address setting register o(PADRO). Low                               |         |                  | ×     |          | ×       | ×       | ×       | ×     |
| Detection address setting register 1(PADR1): Low  Detection address setting register 1(PADR1): Low  Detection address setting register 1(PADR1): Middle  Detection address setting register 1(PADR1): High  Detection address setting register 2(PADR2): Low  Detection address setting register 2(PADR2): Middle  Detection address setting register 2(PADR2): High  Detection address setting register 2(PADR2): High  Detection address setting register 3(PADR3): Low  Detection address setting register 3(PADR3): High  Detection address setting register 4(PADR4): Low  Detection address setting register 4(PADR4): Low  Detection address setting register 4(PADR4): High  Detection address setting register 5(PADR5): Low  Detection address setting register 5(PADR5): Low  Detection address setting register 5(PADR5): High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Detection address setting register 0(PADR0): Middle                            |         |                  |       |          |         | I       |         |       |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3 -3                                                                           |         |                  |       |          |         |         |         |       |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Detection address setting register 0(PADR0): High                              |         |                  |       |          |         |         |         |       |
| Detection address setting register 1(PADR1): Middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                | bit 15  | <b>I</b><br>5 14 | 13    | 12       | 11      | 10      | 9       | 8     |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Detection address setting register 1(PADR1): Low                               | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Middle   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Low   Detection address setting register 4(PADR4): Middle   Detection address setting register 4(PADR4): High   Detection address setting register 4(PADR4): High   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection a   | Detection address acting register 1/DADD1\\ Middle                             | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Middle   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Low   Detection address setting register 4(PADR4): High   Detection address setting register 4(PADR4): High   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): High   Detection address s   | Detection address setting register 1(FADK1). Middle                            | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Middle   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Low   Detection address setting register 4(PADR4): Middle   Detection address setting register 4(PADR4): High   Detection address setting register 4(PADR4): High   Detection address setting register 4(PADR4): High   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection    | Detection address setting register 1(PADR1): High                              |         |                  |       |          |         | 10<br>I |         |       |
| Detection address setting register 2(PADR2): Low   Detection address setting register 2(PADR2): Middle   Detection address setting register 2(PADR2): High   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Low   Detection address setting register 3(PADR3): Middle   Detection address setting register 3(PADR3): High   Detection address setting register 4(PADR4): Low   Detection address setting register 4(PADR4): High   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection addre   | Detection address setting register 1(1 AD1(1), 1 light                         |         |                  |       |          |         |         |         |       |
| bit   15   14   13   12   11   10   9   8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Detection address setting register 2(PADR2): Low                               |         |                  |       |          |         |         |         |       |
| Detection address setting register 2(PADR2): Middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                |         |                  |       | <u> </u> |         |         |         |       |
| Detection address setting register 2(PADR2): High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Detection address setting register 2(PADR2): Middle                            |         |                  | 1     | I        |         |         |         |       |
| Detection address setting register 3(PADR3): Low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Detection address setting register 2(PADR2): High                              | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 3(PADR3): Middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Detection address setting register 3/PADR3): Low                               | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Detection address setting register 3(PADR3): Middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Detection address setting register 5(1 ADN3). Low                              | ×       | ×                | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 3(PADR3): High    Detection address setting register 4(PADR4): Low   Detection address setting register 4(PADR4): Middle   Detection address setting register 4(PADR4): High   Detection address setting register 4(PADR4): High   Detection address setting register 5(PADR5): Low   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): Middle   Detection address setting register 5(PADR5): High   Detection add | Detection address setting register 3(PADR3): Middle                            |         |                  |       |          |         | I       |         |       |
| Name                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3 -3                                                                           |         |                  |       |          |         |         |         |       |
| Detection address setting register 4(PADR4): Low                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Detection address setting register 3(PADR3): High                              |         |                  |       |          |         |         |         |       |
| X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                |         |                  |       |          |         |         |         |       |
| Detection address setting register 4(PADR4): Middle         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Detection address setting register 4(PADR4): Low                               | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 4(PADR4): High    National Column                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Detection of the section 4/DADD 4\ Atillia                                     | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| Detection address setting register 4(PADR4): High         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X <th< td=""><td>Detection address setting register 4(PADR4): iMiddle</td><td>×</td><td>: ×</td><td>×</td><td>×</td><td>×</td><td>×</td><td>×</td><td>×</td></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Detection address setting register 4(PADR4): iMiddle                           | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| Detection address setting register 5(PADR5): Low   bit   7   6   5   4   3   2   1   0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Detection address setting register 4(PADR4): High                              |         |                  |       |          |         |         |         |       |
| Detection address setting register 5(PADR5): Low         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X         X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                |         |                  |       |          |         |         |         |       |
| Detection address setting register 5(PADR5): Middle       bit       15       14       13       12       11       10       9       8         L       X       X       X       X       X       X       X       X       X       X       X         Detection address setting register 5(PADR5): High       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X       X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Detection address setting register 5(PADR5): Low                               |         |                  |       | I        |         |         |         |       |
| Detection address setting register 5(PADR5): Middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                |         |                  |       |          |         |         |         |       |
| Detection address setting register 5(PADR5): High                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Detection address setting register 5(PADR5): Middle                            |         |                  | 1     | I        |         |         |         |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Data di sa alda sa aldi sa assista 5/DADDS \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | bit 7   | 6                | 5     | 4        | 3       | 2       | 1       | 0     |
| ×: Undefined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                | ×       | : ×              | ×     | ×        | ×       | ×       | ×       | ×     |
| A. Ordelined                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | x: Undefined                                                                   |         |                  |       |          |         |         |         |       |

# 22.3.1 Address Detection Control Register (PACSR0/PACSR1)

The address detection control register enables or disables output of an interrupt at an address match. When an address match is detected when output of an interrupt at an address match is enabled, the INT9 interrupt is generated.

#### ■ Address Detection Control Register 0 (PACSR0)



Table 22.3-1 Functions of Address Detection Control Register (PACSR0)

| Bit Name      |                                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|---------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit7,<br>bit6 | Reserved: reserved bits                          | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit5          | AD2E:<br>Address match detection enable bit 2    | The address match detection operation with the detect address setting register 2 (PADR2) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 2 (PADR2) matches with the value of address latch at enabling the address match detection operation (AD2E = 1), the INT9 instruction is immediately executed. |  |  |
| bit4          | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit3          | AD1E:<br>Address match<br>detection enable bit 1 | The address match detection operation with the detect address setting register 1 (PADR1) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 1 (PADR1) matches with the value of address latch at enabling the address match detection operation (AD1E = 1), the INT9 instruction is immediately executed. |  |  |
| bit2          | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit1          | AD0E:<br>Address match<br>detection enable bit 0 | The address match detection operation with the detect address setting register 0 (PADR0) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 0 (PADR0) matches with the value of address latch at enabling the address match detection operation (AD0E = 1), the INT9 instruction is immediately executed. |  |  |
| bit0          | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

#### ■ Address Detection Control Register 1 (PACSR1)



511

Table 22.3-2 Functions of Address Detection Control Register (PACSR1)

| Bit Name        |                                                  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
|-----------------|--------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| bit15,<br>bit14 | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit13           | AD5E:<br>Address match detection enable bit 5    | The address match detection operation with the detect address setting register 5 (PADR5) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 5 (PADR5) matches with the value of address latch at enabling the address match detection operation (AD5E = 1), the INT9 instruction is immediately executed. |  |  |
| bit12           | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit11           | AD4E:<br>Address match<br>detection enable bit 4 | The address match detection operation with the detect address setting register 4 (PADR4) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 4 (PADR4) matches with the value of address latch at enabling the address match detection operation (AD4E = 1), the INT9 instruction is immediately executed. |  |  |
| bit10           | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| bit9            | AD3E:<br>Address match<br>detection enable bit 3 | The address match detection operation with the detect address setting register 3 (PADR3) is enabled or disabled.  When set to 0: Disables the address match detection operation.  When set to 1: Enables the address match detection operation.  • When the value of detect address setting registers 3 (PADR3) matches with the value of address latch at enabling the address match detection operation (AD3E = 1), the INT9 instruction is immediately executed. |  |  |
| bit8            | Reserved: reserved bit                           | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

# 22.3.2 Detect Address Setting Registers (PADR0 to PADR5)

The value of an address to be detected is set in the detect address setting registers. When the address of the instruction processed by the program matches the address set in the detect address setting registers, the next instruction is forcibly replaced by the INT9 instruction, and the interrupt processing program is executed.

#### ■ Detect Address Setting Registers (PADR0 to PADR5)

Figure 22.3-4 Detect Address Setting Registers (PADR0 to PADR5) Address Reset value bit0 bit7 bit6 bit5 bit4 bit3 bit2 bit1 PADR5: High 0079F8н PADR2: High D23 D22 D21 D20 D19 D18 D17 D16 XXXXXXXXB 0079Е8н R/W R/W R/W R/W R/W R/W R/W R/W bit8 Reset value bit15 bit14 bit13 bit12 bit11 bit10 bit9 PADR5: Middle 0079F7H PADR2: Middle D15 D14 D13 D12 D11 D10 D9 D8 XXXXXXXXB 0079E7H R/W R/W R/W R/W R/W R/W R/W R/W Reset value bit2 bit0 bit7 bit6 bit5 bit4 bit3 bit1 PADR5: Low 0079F6н PADR2: Low D7 D6 D5 D4 D3 D2 D1 D0 XXXXXXXXB 0079Е6н R/W R/W R/W R/W R/W R/W R/W R/W bit15 bit14 bit13 bit12 bit11 bit10 bit9 Reset value bit8 PADR4: High 0079F5н D23 D22 D21 D20 D19 D18 D17 D16 XXXXXXXXB PADR1: High 0079Е5н R/W R/W R/W R/W R/W R/W R/W bit7 bit6 bit5 bit4 bit3 bit2 bit1 bit0 Reset value PADR4: Middle 0079F4н D14 D13 D12 D11 D10 PADR1: Middle D15 D9 D8 XXXXXXXXB 0079Е4н R/W R/W R/W R/W R/W R/W R/W R/W bit15 bit14 bit13 bit12 bit11 bit10 bit9 hit8 Reset value PADR4: Low 0079F3н D7 D6 D5 D4 D3 D2 D1 D0 PADR1: Low XXXXXXXXB 0079Е3н R/W R/W R/W R/W R/W R/W R/W R/W bit0 bit7 bit6 bit5 bit4 bit3 bit2 bit1 Reset value PADR3: High 0079F2н D16 D23 D22 D21 D20 D19 D18 D17 XXXXXXXXB PADR0: High 0079Е2н R/W R/W R/W R/W R/W R/W R/W R/W bit8 bit15 bit14 bit13 bit12 bit11 bit10 bit9 Reset value PADR3: Middle 0079F1н D15 D14 D13 D12 D11 D10 D9 D8 PADR0: Middle XXXXXXXXB 0079Е1н R/W R/W R/W R/W R/W R/W R/W R/W bit6 bit5 bit2 bit7 bit4 bit3 bit1 bit0 Reset value PADR3: Low 0079F0н D0 D7 D6 D5 D4 D3 D2 D1 XXXXXXXXB PADR0: Low 0079Е0н R/W R/W R/W R/W R/W R/W R/W R/W R/W: Read/Write : Undefined

# **■** Functions of Detect Address Setting Registers

• There are six detect address setting registers (PADR0 to PADR5) that consist of a high byte (bank), middle byte, and low byte, totaling 24 bits.

Table 22.3-3 Address Setting of Detect Address Setting Registers

| Register Name          | Interrupt<br>Output<br>Enable | Address Setting |                                                  |  |
|------------------------|-------------------------------|-----------------|--------------------------------------------------|--|
| Detect address setting | PACSR0:<br>AD0E               | High            | Set the upper 8 bits of detect address 0 (bank). |  |
| register 0             |                               | Middle          | Set the middle 8 bits of detect address 0.       |  |
| (PADR0)                |                               | Low             | Set the lower 8 bits of detect address 0.        |  |
| Detect address setting | PACSR0:<br>AD1E               | High            | Set the upper 8 bits of detect address 1 (bank). |  |
| register 1             |                               | Middle          | Set the middle 8 bits of detect address 1.       |  |
| (PADR1)                |                               | Low             | Set the lower 8 bits of detect address 1.        |  |
| Detect address setting | PACSR0:<br>AD2E               | High            | Set the upper 8 bits of detect address 2 (bank). |  |
| register 2             |                               | Middle          | Set the middle 8 bits of detect address 2.       |  |
| (PADR2)                |                               | Low             | Set the lower 8 bits of detect address 2.        |  |
| Detect address setting | PACSR1:<br>AD3E               | High            | Set the upper 8 bits of detect address 3 (bank). |  |
| register 3             |                               | Middle          | Set the middle 8 bits of detect address 3.       |  |
| (PADR3)                |                               | Low             | Set the lower 8 bits of detect address 3.        |  |
| Detect address setting |                               | High            | Set the upper 8 bits of detect address 4 (bank). |  |
| register 4             | er 4 PACSR1:                  |                 | Set the middle 8 bits of detect address 4.       |  |
| (PADR4)                |                               | Low             | Set the lower 8 bits of detect address 4.        |  |
| Detect address setting | PACSR1:<br>AD5E               | High            | Set the upper 8 bits of detect address 5 (bank). |  |
| register 5             |                               | Middle          | Set the middle 8 bits of detect address 5.       |  |
| (PADR5)                |                               | Low             | Set the lower 8 bits of detect address 5.        |  |

<sup>•</sup> In the detect address setting registers (PADR0 to PADR5), starting address (first byte) of instruction to be replaced by INT9 instruction should be set.

Figure 22.3-5 Setting of Starting Address of Instruction Code to be Replaced by INT9 Instruction



#### **Notes:**

- When an address of other than the first byte is set to the detect address setting registers (PADR0 to PADR5), the instruction code is not replaced by INT9 instruction and a program of an interrupt processing is not be performed. When the address is set to the second byte or subsequent, the address set by the instruction code is replaced by "01" (INT9 instruction code) and, which may cause malfunction.
- The detect address setting registers (PADR0 to PADR5) should be set after disabling the address match detection (PACSR: ADnE=0) of corresponding address match control registers. If the detect address setting registers are changed without disabling the address match detection, the address match detection function will work immediately after an address match occurs during writing address, which may cause malfunction.
- The address match detection function can be used only for addresses of the internal ROM area. If
  addresses of the external memory area are set, the address match detection function will not work
  and the INT9 instruction will not be executed.

# 22.4 Explanation of Operation of Address Match Detection Function

If the addresses of the instructions executed in the program match those set in the detection address setting registers (PADR0 to PADR5), the address match detection function will replace the first instruction code executed by the CPU with the INT9 instruction ( $01_{\rm H}$ ) to branch to the interrupt processing program.

#### ■ Operation of Address Match Detection Function

Figure 22.4-1 shows the operation of the address match detection function when the detect addresses are set and an address match is detected.

Program execution Address Instruction code Mnemonic The instruction address to be FF001C: A8 00 00 MOVW RW0,#0000 executed by program matches FF001F: (4A)00 00 MOVW A,#0000 detect address setting register 0 FF0022: A,#0880 4A 80 08 MOVW

Figure 22.4-1 Operation of Address Match Detection Function

# ■ Setting Detect Address

1) Disable the detection address setting register 0 (PADR0) where the detect address is set for address match detection (PACSR0: AD0E=0).

Replaced by INT9 instruction (01H)

- 2) Set the detect address in the detection address setting register 0 (PADR0). Set "FF<sub>H</sub>" at the higher bits, " $00_H$ " at the middle bits, and " $1F_H$ " at the lower bits of the detection address setting register 0 (PADR0).
- 3) Enable the detect address setting register 0 (PADR0) where the detect address is set for address match detection (PACSR0: AD0E=1).

#### ■ Program Execution

- 1) If the address of the instruction to be executed in the program matches the set detect address, the first instruction code at the matched address is replaced by the INT9 instruction code ("01<sub>H</sub>").
- 2) INT9 instruction is executed. INT9 interrupt is generated and then interrupt processing program is executed.

#### 22.4.1 **Example of using Address Match Detection Function**

This section gives an example of patch processing for program correction using the address match detection function.

# ■ System Configuration and E<sup>2</sup>PROM Memory Map

System configuration

Figure 22.4-2 gives an example of the system configuration using the address match detection function.

Figure 22.4-2 Example of System Configuration Using Address Match Detection Function



# **■** E<sup>2</sup>PROM Memory Map

Figure 22.4-3 shows the allocation of the patch program and data at storing the patch program in E<sup>2</sup>PROM.



#### Figure 22.4-3 Allocation of E<sup>2</sup>PROM Patch Program and Data

#### Patch program byte count

The total byte count of the patch program (main body) is stored. If the byte count is "00<sub>H</sub>", it indicates that no patch program is provided.

#### Detect address (24 bits)

The address where the instruction code is replaced by the INT9 instruction code due to program error is stored. This address is set in the detection address setting registers (PADR0 to PADR5).

#### Patch program (main body)

The program executed by the INT9 interrupt processing when the program address matches the detect address is stored. Patch program 0 is allocated from any predetermined address. Patch program 1 is allocated from the address indicating <starting address of patch program 0 + total byte count of patch program 0>.

It is similar for the correction program 2 to 5.

#### **■** Setting and Operating State

#### Initialization

 $E^2$ PROM data are all cleared to " $00_H$ ".

#### Occurrence of program error

- By using the connector (UART), information about the patch program is transmitted to the MCU (F<sup>2</sup>MC16LX) from the outside according to the allocation of the E<sup>2</sup>PROM patch program and data.
- The MCU (F<sup>2</sup>MC16LX) stores the information received from outside in the E<sup>2</sup>PROM.

#### Reset sequence

- After reset, the MCU (F<sup>2</sup>MC16LX) reads the byte count of the E<sup>2</sup>PROM patch program to check the presence or absence of the correction program.
- If the byte count of the patch program is not "00<sub>H</sub>", the higher, middle and lower bits at detect addresses 0 to 5 are read and set in the detection address setting registers 0 to 5 (PADR0 to PADR5). The patch program (main body) is read according to the byte count of the patch program and written to RAM in the MCU (F<sup>2</sup>MC16LX).
- The patch program (main body) is allocated to the address where the patch program is executed in the INT9 interrupt processing by the address match detection function.
- Address match detection is enabled (PACSR: AD0E=1, AD1E=1 ... AD5E=1).

#### INT9 Interrupt processing

- Interrupt processing is performed by the INT9 instruction. The MB90360 series has no interrupt request flag by address match detection. Therefore, if the stack information in the program counter is discarded, the detect address cannot be checked. When checking the detect address, check the value of program counter stacked in the interrupt processing routine.
- The patch program is executed, branching to the normal program.

# ■ Operation of Address Match Detection Function at Storing Patch Program in E<sup>2</sup>PROM

Figure 22.4-4 shows the operation of the address match detection function at storing the patch program in  $E^2$ PROM.

Figure 22.4-4 Operation of Address Match Detection Function at Storing Patch Program in E<sup>2</sup>PROM



- (1) Execution of detection address setting of reset sequence and normal program
- (2) Branch to patch program which expanded in RAM with INT9 interrupt processing by address match detection
- (3) Patch program execution by branching of INT9 processing
- (4) Execution of normal program which branches from patch program

#### **■** Flow of Patch Processing for Patch Program

Figure 22.4-5 shows the flow of patch processing for patch program using the address match detection function.



Figure 22.4-5 Flow of Patch Processing for Patch Program

# 22.5 Program Example of Address Match Detection Function

This section gives a program example for the address match detection function.

#### ■ Program Example for Address Match Detection Function

#### Processing specifications

If the address of the instruction to be executed by the program matches the address set in the detection address setting register (PADR0), the INT9 instruction is executed.

#### Coding example

```
;Address detection control register 0
PACSR0 EQU
            00009EH
PADRL EOU
                             ;Detection address setting register 0
            0079E0H
                             (Low)
                             ;Detection address setting register 0
PADRM EQU
            0079E1H
PADRH EQU
           0079E2H
                             ;Detection address setting register 0
                             (High)
;-----Main program------
CODE
      CSEG
START:
                             ;Stack pointer (SP), etc.,
                            ;already initialized
                            ;Set address detection register 0
            PADRL, #00H
      VOM
                             (Low)
            PADRM, #00H
                            ;Set address detection register 0
      MOV
                            (Middle)
      VOM
            PADRH, #00H
                            ;Set address detection register 0
                            (High)
      MOV
            I:PACSR0, #00000010B ;Enable address match
      processing by user
LOOP:
      processing by user
      BRA
            LOOP
;-----Interrupt program------
WARI:
      processing by user
```

#### CHAPTER 22 ADDRESS MATCH DETECTION FUNCTION

RETI ;Return from interrupt processing CODE ENDS ;------Vector setting------VECT CSEG ABS=0FFH ORG 00FFD8H WARI DSL ORG 00FFDCH ;Set reset vector DSL START DB 00H ;Set to single-chip mode VECT ENDS END START

#### CHAPTER 22 ADDRESS MATCH DETECTION FUNCTION

# **CHAPTER 23**

# ROM MIRRORING MODULE

This chapter describes the functions and operations of the ROM mirroring function select module.

- 23.1 Overview of ROM Mirroring Function Select Module
- 23.2 ROM Mirroring Function Select Register (ROMM)

# 23.1 Overview of ROM Mirroring Function Select Module

The ROM mirroring function select module provides a setting so that ROM data in the FF bank can be read by access to the 00 bank.

# ■ Block Diagram of ROM Mirroring Function Select Module

Figure 23.1-1 Block Diagram of ROM Mirroring Function Select Module



# ■ Access to FF Bank by ROM Mirroring Function

Figure 23.1-2 shows the location in memory when ROM mirroring function allows access to the 00 bank to read ROM data in the FF bank.

Figure 23.1-2 Access to FF Bank by ROM Mirroring Function

# ■ Memory Space when ROM Mirroring Function Enabled/Disabled

Figure 23.1-3 shows the availability of access to memory space when the ROM mirroring function is enabled or disabled.



Figure 23.1-3 Memory Space when ROM Mirroring Function Enabled/Disabled

# ■ List of Registers and Reset Values of ROM Mirroring Function Select Module

Figure 23.1-4 List of Registers and Reset Values of ROM Mirroring Function Select Module



# 23.2 ROM Mirroring Function Select Register (ROMM)

The ROM mirroring function select register (ROMM) enables or disables the ROM mirroring function. When the ROM mirroring function is enabled, ROM data in the FF bank can be read by access to the 00 bank.

# ■ ROM Mirroring Function Select Register (ROMM)



Figure 23.2-1 ROM Mirroring Function Select Register (ROMM)

Table 23.2-1 Functions of ROM Mirroring Function Select Register (ROMM)

|                     | Bit Name                                    | Function                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit8                | MI:<br>ROM mirroring<br>function select bit | This bit enables or disables the ROM mirroring function.  When set to 0: Disables ROM mirroring function  When set to 1: Enables ROM mirroring function  When the ROM mirroring function is enabled (MI = 1), data at ROM addresses "FF8000 <sub>H</sub> " to "FFFFFF <sub>H</sub> " can be read by accessing addresses "008000 <sub>H</sub> " to "00FFFF <sub>H</sub> ". |
| bit9<br>to<br>bit15 | Undefined bits                              | Read: Value is undefined. Write: No effect                                                                                                                                                                                                                                                                                                                                |

#### Note:

While the ROM area at addresses " $008000_{\rm H}$ " to " $00{\rm FFFF}_{\rm H}$ " is being used, access to the ROM mirroring function select register (ROMM) is prohibited.

# **CHAPTER 24**

# 512K-BIT FLASH MEMORY

This chapter explains the functions and operation of the 512K-bit flash memory. The following three methods are available for writing data to and erasing data from the flash memory:

- Parallel programmer
- Serial programmer
- Executing programs to write/erase data This chapter explains "Executing programs to write/erase data".
- 24.1 Overview of 512K-bit Flash Memory
- 24.2 Block Diagram of the Entire Flash Memory and Sector Configuration of the Flash Memory
- 24.3 Write/Erase Modes
- 24.4 Flash Memory Control Status Register (FMCS)
- 24.5 Starting the Flash Memory Automatic Algorithm
- 24.6 Confirming the Automatic Algorithm Execution State
- 24.7 Detailed Explanation of Writing to and Erasing Flash Memory
- 24.8 Notes on Using 512K-bit Flash Memory
- 24.9 Flash Security Feature

# 24.1 Overview of 512K-bit Flash Memory

The 512K-bit flash memory is mapped to the  $FF_H$  bank in the CPU memory map. The functions of the flash memory interface circuit enable read-access and program-access from the CPU in the same way as mask ROM. Instructions from the CPU can be used via the flash memory interface circuit to write data to and erase data from the flash memory. Internal CPU control therefore enables rewriting of the flash memory while it is mounted. As a result, improvements in programs and data can be performed efficiently.

# ■ 512K-bit Flash Memory Features

- Use of automatic program algorithm (Embedded Algorithm<sup>TM\*</sup>: Equivalent to MBM29LV200)
- Detection of completion of writing/erasing using data polling or toggle bit functions
- Detection of completion of writing/erasing using CPU interrupts
- Minimum of 10,000 write/erase operations
- Flash reading cycle time: Minimum of 2 machine cycles

#### Note:

The manufacturer code and device code do not have the reading function. These codes cannot be accessed by the command.

# ■ Writing to/erasing Flash Memory

The flash memory cannot be written to and erased at the same time. That is, when data is written to or erased data from the flash memory, the program in the flash memory must first be copied to RAM. The entire process is then executed in RAM so that data is simply written to the flash memory. This eliminates the need for the program to access the flash memory from the flash memory itself.

# ■ Flash Memory Control Status Register (FMCS)



<sup>\*:</sup> Embedded Algorithm<sup>TM</sup> is a trademark of Advanced Micro Devices, Inc.

# 24.2 **Block Diagram of the Entire Flash Memory and Sector Configuration of the Flash Memory**

Figure 24.2-1 shows a block diagram of the entire flash memory with the flash memory interface circuit included. Figure 24.2-2 shows the sector configuration of the flash memory.

# ■ Block Diagram of the Entire Flash Memory



■ Sector Configuration of the 512K-bit Flash Memory

Figure 24.2-2 shows the sector configuration of the 512K-bit flash memory. The addresses in the figure indicate the high-order and low-order addresses of each sector.

Figure 24.2-2 Sector Configuration of the 512K-bit Flash Memory



lel programmer. When a general programmer is used for writing/erasing, this address is used for writing/erasing.

# 24.3 Write/Erase Modes

The flash memory can be accessed in 2 different ways: Flash memory mode and alternative mode. Flash memory mode enables data to be directly written to or erased from the external pins. Alternative mode enables data to be written to or erased from the CPU via the internal bus. Use the mode external pins to select the mode.

# **■** Flash Memory Mode

The CPU stops when the mode pins are set to "111<sub>B</sub>" while the reset signal is asserted. The flash memory interface circuit is connected directly to ports 2, 4 and 5, enabling direct control from the external pins. This mode makes the MCU seem like a standard flash memory to the external pins, and write/erase can be performed using a flash memory programmer.

In flash memory mode, all operations supported by the flash memory automatic algorithm can be used.

#### **■** Alternative Mode

The flash memory is located in the FF bank in the CPU memory space, and like ordinary mask ROM, can be read-accessed and program-accessed from the CPU via the flash memory interface circuit.

Since writing/erasing the flash memory is performed by instructions from the CPU via the flash memory interface circuit, this mode allows rewriting even when the MCU is soldered on the target board.

# **■** Flash Memory Control Signals

Table 24.3-1 lists the flash memory control signals in flash memory mode.

The flash memory control signals and the external pin of the MBM29LV200 have one-to-one relationship.

In flash memory mode, the external data bus signal width is limited to 8 bits, enabling only 1 byte access. The DQ15 to DQ8 pins are not supported. The  $\overline{BYTE}$  pin should always be set to 0.

Table 24.3-1 Flash Memory Control Signals (Developing: it is possible to change)

| MB90F362/T(S), M | MB90F362/T(S), MB90F367/T(S) |                   |                         |
|------------------|------------------------------|-------------------|-------------------------|
| Pin number       | Normal function              | Flash memory mode |                         |
| LQFP             |                              |                   |                         |
| 42               | P83                          | AQ16              | A15                     |
| 38               | P87                          | CE                | CE                      |
| 39               | P86                          | ŌE                | ŌE                      |
| 40               | P43                          | WE                | WE                      |
| 41 (45)          | P42(P44)                     | AQ17 (AQ18)       | A16                     |
| 37               | P85                          | BYTE              | BYTE                    |
| 11               | P80                          | RY/BY             | RY/BY                   |
| 12 to 19         | P50 to P57                   | AQ8 to AQ15       | A7 to A14               |
| 21               | MD1                          | MD1               | RESET(V <sub>ID</sub> ) |
| 20               | MD2                          | MD2               | OE(V <sub>ID</sub> )    |
| 3 to 10          | P60 to P67                   | DQ0 to DQ7        | DQ0 to DQ7              |
| 23               | RST                          | RESET             | RESET                   |
| 29 to 36         | P27 to P20                   | AQ0 to AQ7        | A-1, A0 to A6           |

# 24.4 Flash Memory Control Status Register (FMCS)

This section shows the function of the flash memory control status register (FMCS).

# ■ Flash Memory Control Status Register (FMCS)



Table 24.4-1 Functions of Control Status Register (FMCS)

|                    | Bit Name                                                             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------------|----------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| bit7               | INTE:<br>Flash memory<br>programming/erasing<br>interrupt enable bit | This bit enables or disables an interrupt as programming/erasing flash memory is terminated.  When set to 1: If the flash memory operation flag bit is set to 1 (FMCS: RDYINT=1), an interrupt is requested.                                                                                                                                                                                                                                                                                                                                                      |
| bit6               | RDYINT:<br>Flash memory<br>operation flag bit                        | This bit shows the operating state of flash memory.  If programming/erasing flash memory is terminated, the RDYINT bit is set to 1 in timing of termination of the flash memory automatic algorithm.  If the RDYINT bit is set to 1 when an interrupt as programming/erasing flash memory is terminated is enabled (FMCS:INTE = 1), an interrupt is requested.  If the RDYINT bit is 0, programming/erasing flash memory is disabled.  When set to 0: Cleared.  When set to 1: No effect  If the read-modify-write (RMW) instructions are used, 1 is always read. |
| bit5               | WE:<br>Flash memory<br>programming/erasing<br>enable bit             | This bit enables or disables the programming/erasing of flash memory.  The WE bit should be set before starting the command to program/erase flash memory.  When set to 0: No program/erase signal is generated even if the command to program/erase the FF bank is inputted.  When set to 1: Programming/erasing flash memory is enabled after inputting program/erase command to the FF bank.  When not performing programming/erasing, the WE bit should be set to 0 so as not to accidentally program or erase flash memory.                                  |
| bit4               | RDY:<br>Flash memory<br>programming/erasing<br>status bit            | This bit shows the programming/erasing status of flash memory.  If the RDY bit is 0, programming/erasing flash memory is disabled.  The read/reset command can be accepted even if the RDY bit is 0. The RDY bit is set to 1 when programming/erasing is completed.                                                                                                                                                                                                                                                                                               |
| bit3<br>to<br>bit0 | Reserved: Reserved bits                                              | Always set to 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

#### Note:

- The RDYINT and RDY bits cannot be changed at the same time. Create a program so that decisions are made using one or the other of these bits. (See Figure 24.4-2.)
- This register can be accessed only in byte-access mode.





# 24.5 Starting the Flash Memory Automatic Algorithm

Three types of commands are available for starting the flash memory automatic algorithm: Read/Reset, Write, and Chip Erase.

# **■** Command Sequence Table

Table 24.5-1 lists the commands used for flash memory write/erase. All of the data written to the command register is in bytes, but use word access to write. The data of the high-order bytes at this time is ignored.

**Table 24.5-1 Command Sequence Table** 

| Command sequence | write  | 1st bus |      | 2nd bus |      | 3rd bus |      | 4th bus |              | 5th bus |      | 6th bus<br>cycl |      |
|------------------|--------|---------|------|---------|------|---------|------|---------|--------------|---------|------|-----------------|------|
|                  | access | Address | Data | Address | Data | Address | Data | Address | Data         | Address | Data | Address         | Data |
| Read/<br>reset*  | 1      | FFXXXX  | XXF0 | -       | -    | -       | -    | -       | -            | -       | -    | -               | -    |
| Read/<br>reset*  | 4      | FFAAAA  | XXAA | FF5554  | XX55 | FFAAAA  | XXF0 | RA      | RD           | -       | -    | -               | -    |
| Write<br>program | 4      | FFAAAA  | XXAA | FF5554  | XX55 | FFAAAA  | XXA0 |         | PD<br>(word) | -       | -    | -               | -    |
| Chip erase       | 6      | FFAAAA  | XXAA | FF5554  | XX55 | FFAAAA  | XX80 | FFAAAA  | XXAA         | FF5554  | XX55 | FFAAAA          | XX10 |

Notes: • Addresses in the table are the values in the CPU memory map. All addresses and data are hexadecimal values, where "x" is any value.

- RA: Read address
- PA: Program address. Only even addresses can be specified.
- RD: Read data
- PD: Program data. Only word data can be specified.

<sup>\*:</sup> Two kinds of read/reset commands can reset flash memory to the read mode.

# 24.6 Confirming the Automatic Algorithm Execution State

Because the write/erase flow of the flash memory is controlled using the automatic algorithm, the flash memory has hardware for posting its internal operating state and completion of operation. This automatic algorithm enables confirmation of the operating state of the built-in flash memory using the following hardware sequences flag.

# ■ Hardware Sequence Flags

The hardware sequence flags are configured from the three-bit output of DQ7, DQ6, and DQ5. The functions of these bits are those of the data polling flag (DQ7), toggle bit flag (DQ6), and timing limit exceeded flag (DQ5). The hardware sequence flags can therefore be used to confirm that writing or chip erase has been completed or that erase code write is valid.

The hardware sequence flags can be accessed by read-accessing the addresses of the target sectors in the flash memory after setting of the command sequence (see Table 24.5-1). Table 24.6-1 lists the bit assignments of the hardware sequence flags.

Table 24.6-1 Bit Assignments of Hardware Sequence Flags

| Bit No.                | 7   | 6   | 5   | 4 | 3 | 2 | 1 | 0 |
|------------------------|-----|-----|-----|---|---|---|---|---|
| Hardware sequence flag | DQ7 | DQ6 | DQ5 | ı | ı | - | ı | - |

#### CHAPTER 24 512K-BIT FLASH MEMORY

To determine whether automatic writing or chip erase is being executed, the hardware sequence flags can be checked or the status can be determined from the RDY bit of the flash memory control status register (FMCS) that indicates whether writing has been completed. After writing/erasing has terminated, the state returns to the read/reset state. When creating a program, use one of the flags to confirm that automatic writing/erasing has terminated. Then, perform the next processing operation, such as data read. The following sections describe each hardware sequence flag separately. Table 24.6-2 lists the functions of the hardware sequence flags.

Table 24.6-2 Hardware Sequence Flag Function

| State                             |                                                   | DQ7                                 | DQ6             | DQ5                       |
|-----------------------------------|---------------------------------------------------|-------------------------------------|-----------------|---------------------------|
| State change for normal operation | Write → Write completed (write address specified) | $\overline{DQ7} \rightarrow$ DATA:7 | Toggle → DATA:6 | $0 \rightarrow \\ DATA:5$ |
|                                   | Chip/selector erase → Erase completed             | $0 \rightarrow 1$                   | Toggle → Stop   | $0 \rightarrow 1$         |
| Abnormal operation                | Write                                             | <del>DQ7</del>                      | Toggle          | 1                         |
|                                   | Chip erase                                        | 0                                   | Toggle          | 1                         |

# 24.6.1 Data Polling Flag (DQ7)

The data polling flag (DQ7) uses the data polling function to post that the automatic algorithm is being executed or has terminated

# ■ Data Polling Flag (DQ7)

Table 24.6-3 and Table 24.6-4 list the state transitions of the data polling flag.

Table 24.6-3 State Transition of Data Polling Flag (State change at normal operation)

| Operating State | Programming  → Completed                      | Chip Erasing → Completed |
|-----------------|-----------------------------------------------|--------------------------|
| DQ7             | $\overline{\mathrm{DQ7}} \to \mathrm{DATA:7}$ | $0 \rightarrow 1$        |

Table 24.6-4 State Transition of Data Polling Flag (State change at abnormal operation)

| Operating State | Programming    | Chip Erasing |
|-----------------|----------------|--------------|
| DQ7             | <del>DQ7</del> | 0            |

#### Write

Read-access during execution of the automatic write algorithm causes the flash memory to output the opposite data of bit 7 last written, regardless of the value at the address specified by the address signal. Read-access at the end of the automatic write algorithm causes the flash memory to output bit 7 of the read value of the address specified by the address signal.

## Chip erase

Read-access during execution of the chip erase algorithm causes the flash memory to output 0. Read-access at the end of the automatic chip algorithm causes the flash memory to output 1 in the same way.

#### Note:

When the automatic algorithm is being started, read-access to the specified address is ignored. Since termination of the data polling flag (DQ7) can be accepted for a data read and other bits output, data read after the automatic algorithm has terminated should be performed after read-access has confirmed that data polling has terminated.

# 24.6.2 Toggle Bit Flag (DQ6)

Like the data polling flag (DQ7), the toggle bit flag (DQ6) uses the toggle bit function to post that the automatic algorithm is being executed or has terminated.

# ■ Toggle Bit Flag (DQ6)

Table 24.6-5 and Table 24.6-6 list the state transitions of the toggle bit flag.

Table 24.6-5 State Transition of Toggle Bit Flag (State change at normal operation)

| Operating State | $\begin{array}{c} \text{Programming} \\ \rightarrow \text{Completed} \end{array}$ | Chip Erasing → Completed  |
|-----------------|-----------------------------------------------------------------------------------|---------------------------|
| DQ6             | Toggle → DATA:6                                                                   | $Toggle \rightarrow Stop$ |

Table 24.6-6 State Transition of Toggle Bit Flag (State change at abnormal operation)

| Operating State | Programming | Chip Erasing |
|-----------------|-------------|--------------|
| DQ6             | Toggle      | Toggle       |

## Write/chip erase

Continuous read-access during execution of the automatic write algorithm and chip erase algorithm causes the flash memory to toggle the 1 or 0 state for every read cycle, regardless of the value at the address specified by the address signal. Continuous read-access at the end of the automatic write algorithm and chip erase algorithm causes the flash memory to stop toggling bit 6 and output bit 6 (DATA: 6) of the read value of the address specified by the address signal.

# 24.6.3 Timing Limit Exceeded Flag (DQ5)

The timing limit exceeded flag (DQ5) is used to post that execution of the automatic algorithm has exceeded the time (internal pulse count) prescribed in the flash memory.

# ■ Timing Limit Exceeded Flag (DQ5)

Table 24.6-7 and Table 24.6-8 list the state transitions of the timing limit exceeded flag.

Table 24.6-7 State Transition of Timing Limit Exceeded Flag (State change at normal operation)

| Operating State | Programming  → Completed      | Chip Erasing $\rightarrow$ Completed |
|-----------------|-------------------------------|--------------------------------------|
| DQ5             | $0 \rightarrow \text{DATA:5}$ | $0 \rightarrow 1$                    |

Table 24.6-8 State Transition of Timing Limit Exceeded Flag (State change at abnormal operation)

| Operating State | Programming | Chip Erasing |
|-----------------|-------------|--------------|
| DQ5             | 1           | 1            |

## Write/chip erase

Read-access after write or chip erase automatic algorithm activation causes the flash memory to output 0 if the time is within the prescribed time (time required for write/erase) or to output 1 if the prescribed time has been exceeded. Because this is done regardless of whether the automatic algorithm is being executed or has terminated, it is possible to determine whether write/erase was successful or unsuccessful. That is, when this flag outputs 1, writing can be determined to have been unsuccessful if the automatic algorithm is still being executed by the data polling function or toggle bit function.

For example, writing 1 to a flash memory address where 0 has been written will cause the fail state to occur. In this case, the flash memory will lock and execution of the automatic algorithm will not terminate. In rare cases normal termination may be seen as with the case where "1" can be written. As a result, valid data will not be outputted from the data polling flag (DQ7). In addition, the toggle bit flag (DQ6) will exceed the time limit without stopping the toggle operation and the timing limit exceeded flag (DQ5) will output 1. Note that this state indicates that the flash memory is not faulty, but has not been used correctly. When this state occurs, execute the Reset command.

# 24.7 Detailed Explanation of Writing to and Erasing Flash Memory

This section describes each operation procedure of flash memory Read/Reset, Write, Chip Erase when a command that starts the automatic algorithm is issued.

# ■ Detailed Explanation of Flash Memory Write/erase

The flash memory executes the automatic algorithm by issuing a command sequence (see Table 24.5-1) for a write cycle to the bus to perform Read/Reset, Write, or Chip Erase operations. Each bus write cycle must be performed continuously. In addition, whether the automatic algorithm has terminated can be determined using the data polling or other function. At normal termination, the flash memory is returned to the read/reset state.

Each operation of the flash memory is described in the following order:

- Setting the read/reset state
- · Writing data
- Erasing all data (erasing chips)

# 24.7.1 Setting The Read/Reset State

This section describes the procedure for issuing the Read/Reset command to set the flash memory to the read/reset state.

# ■ Setting the Flash Memory to the Read/reset State

The flash memory can be set to the read/reset state by sending the Read/Reset command in the command sequence table (see Table 24.5-1) continuously to the target sector in the flash memory.

The Read/Reset command has two types of command sequences that execute the first and third bus operations. However, there are no essential differences between these command sequences.

The read/reset state is the initial state of the flash memory. When the power is turned on and when a command terminates normally, the flash memory is set to the read/reset state. In the read/reset state, other commands wait for input.

In the read/reset state, data is read by regular read-access. As with the mask ROM, program access from the CPU is enabled. The Read/Reset command is not required to read data by a regular read. The Read/Reset command is mainly used to initialize the automatic algorithm in such cases as when a command does not terminate normally.

# 24.7.2 Writing Data

This section describes the procedure for issuing the Write command to write data to the flash memory.

# ■ Writing Data to the Flash Memory

The data write automatic algorithm of the flash memory can be started by sending the Write command in the command sequence table (see Table 24.5-1) continuously to the target sector in the flash memory. When data write to the target address is completed in the fourth cycle, the automatic algorithm and automatic write are started.

#### Specifying addresses

Only even addresses can be specified as the write addresses specified in a write data cycle. Odd addresses cannot be written correctly. That is, writing to even addresses must be done in units of word data.

Writing can be done in any order of addresses. However, the Write command writes only data of one word for each execution.

#### Notes on writing data

Writing cannot return data 0 to data 1. When data 1 is written to data 0, the data polling algorithm (DQ7) or toggle operation (DQ6) does not terminate and the flash memory elements are determined to be faulty. If the time prescribed for writing is thus exceeded, the timing limit exceeded flag (DQ5) is determined to be an error. Otherwise, the data is viewed as if dummy data 1 had been written. However, when data is read in the read/reset state, the data remains 0. Data 0 can be set to data 1 only by erase operations.

All commands are ignored during execution of the automatic write algorithm. If a hardware reset is started during writing, the data of the written addresses will be unpredictable.

## ■ Writing to the Flash Memory

Figure 24.7-1 is an example of the procedure for writing to the flash memory. The hardware sequence flags (see "24.6 Confirming the Automatic Algorithm Execution State") can be used to determine the state of the automatic algorithm in the flash memory. Here, the data polling flag (DQ7) is used to confirm that writing has terminated.

The data read to check the flag is read from the address written to last.

The data polling flag (DQ7) changes at the same time that the timing limit exceeded flag (DQ5) changes. For example, even if the timing limit exceeded flag (DQ5) is 1, the data polling flag bit (DQ7) must be rechecked.

Also for the toggle bit flag (DQ6), the toggle operation stops at the same time that the timing limit exceeded flag bit (DQ5) changes to 1. The toggle bit flag (DQ6) must therefore be rechecked.



Figure 24.7-1 Example of the Flash Memory Write Procedure

# 24.7.3 Erasing All Data (Erasing Chips)

This section describes the procedure for issuing the Chip Erase command to erase all data in the flash memory.

# ■ Erasing all Data in the Flash Memory (Erasing chips)

All data can be erased from the flash memory by sending the Chip Erase command in the command sequence table (see Table 24.5-1) continuously to the target sector in the flash memory.

The Chip Erase command is executed in six bus operations. When writing of the sixth cycle is completed, the chip erase operation is started. For chip erase, the user need not write to the flash memory before erasing. During execution of the automatic erase algorithm, the flash memory writes 0 for verification before all of the cells are erased automatically.

# **■** Erasing Chip in the Flash Memory

The hardware sequence flags (see "24.6 Confirming the Automatic Algorithm Execution State") can be used to determine the state of the automatic algorithm in the flash memory. Figure 24.7-2 is an example of the procedure for erasing chip in the flash memory. Here, the toggle bit flag (DQ6) is used to confirm that erasing has terminated.

The data that is read to check the flag is read from the sector to be erased.

The toggle bit flag (DQ6) stops the toggle operation at the same time that the timing limit exceeded flag (DQ5) is changed to 1. For example, even if the timing limit exceeded flag (DQ5) is 1, the toggle bit flag (DQ6) must be rechecked.

The data polling flag (DQ7) also changes at the same time that the timing limit exceeded flag bit (DQ5) changes. As a result, the data polling flag (DQ7) must be rechecked.



Figure 24.7-2 Example of the Flash Memory Chip Procedure

# 24.8 Notes on Using 512K-bit Flash Memory

# This section contains notes on using 512K-bit flash memory.

# ■ Notes on Using Flash Memory

# ■ Input of a hardware reset (RST)

To input a hardware reset when the automatic algorithm has not been started and reading is in progress, a minimum "L" level width of 500 ns must be maintained. In this case, a maximum of 500 ns is required until data can be read from the flash memory after a hardware reset has been activated.

Similarly, to input a hardware reset when the automatic algorithm has been activated and writing or erasing is in progress, a minimum "L" level width of 500 ns must be maintained. In this case,  $20~\mu s$  are required until data can be read after the operation for initializing the flash memory has terminated.

When a hardware reset is performed during writing, the data being written is undefined.

#### Canceling of a software reset and watchdog timer reset

When the flash memory is being written to or erased with CPU access and if reset conditions occur while the automatic algorithm is active, the CPU may run out of control. This occurs because these reset conditions cause the automatic algorithm to continue without initializing the flash memory unit, possibly preventing the flash memory unit from entering the read state when the CPU starts the sequence after the reset has been deasserted. These reset conditions must be disabled during writing to or erasing of the flash memory.

#### Program access to flash memory

When the automatic algorithm is operating, read access to the flash memory is disabled. With the memory access mode of the CPU set to internal ROM mode, writing or erasing must be started after the program area is switched to another area such as RAM.

# Extended intelligent I/O service (EI<sup>2</sup>OS)

Because write and erase interrupts issued to the CPU from the flash memory interface circuit cannot be accepted by the EI<sup>2</sup>OS, they should not be used.

# 24.9 Flash Security Feature

# Flash security feature provides possibilities to protect the content of the flash memory.

## ■ Abstract

By writing the protection code of " $01_{\rm H}$ " to the security bit in the flash memory, access to the flash memory is restricted. Once the flash memory is protected, performing the chip erase operation only can unlock the function. Otherwise, read/write access to the flash memory from the external pins is not possible.

This function is suitable for applications requiring security of self-containing and data stored in the flash memory.

Address of the security bit depends on the size of built-in flash memory. Table 24.9-1 shows the address of security bit.

### Table 24.9-1 Address of Flash Security Bit

|                              | Flash memory size              | Address of security bit |
|------------------------------|--------------------------------|-------------------------|
| MB90F362/T(S), MB90F367/T(S) | Built-in 512K-bit flash memory | FF0001 <sub>H</sub>     |

# ■ How to Enable the Flash Security Feature

After writing the protection code " $01_{\rm H}$ " to the security bit, the following external reset or power-on enables the Flash Security Feature.

# ■ How to Disable the Flash Security Feature

Performing the chip erase operation.

# ■ Behavior Under the Flash Security Feature

Read operation: invalid data read

Write operation: ignored

#### Others

- (1) About configuration of the general-purpose parallel programmer, please follow to the specification of parallel programmer.
- (2) Writing the protection code at the last of flash memory programming is recommended, in order to prevent the device from enabling the Flash Security Feature accidentally.

#### **Notes:**

- The flash security bit is allocated in the flash memory area. When the protection code "01<sub>H</sub>" is written to
  the security bit, it is locked by the security. So, when not using the security function, do not write "01<sub>H</sub>"
  to this address.
  - See Table 24.9-1 for the address of the security bit.
- By specifying the sector of the flash memory, it cannot be locked the security per sector. It is the security function for all areas in the flash memory.
- The FLASH memory trouble in the state to put security cannot be analyzed at all.

# CHAPTER 25

# EXAMPLES OF MB90F362/T(S), MB90F367/T(S) SERIAL PROGRAMMING CONNECTION

This chapter shows an example of a serial programming connection using the AF220/AF210/AF120/AF110 Flash Micro-computer Programmer by Yokogawa Digital Computer Corporation when the AF220/AF210/AF120/AF110 flash serial microcontroller programer from Yokogawa Digital Computer Corporation is used.

- 25.1 Basic Configuration of Serial Programming Connection with MB90F362/T(S), MB90F367/T(S)
- 25.2 Example of Serial Programming Connection (User Power Supply Used)
- 25.3 Example of Serial Programming Connection (Power Supplied from Programmer)
- 25.4 Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply Used)
- 25.5 Example of Minimum Connection to Flash Microcontroller Programmer (Power Supplied from Programmer)

# 25.1 Basic Configuration of Serial Programming Connection with MB90F362/T(S), MB90F367/T(S)

The MB90F362/T(S), MB90F367/T(S) supports on-board writing (Fujitsu standard) of the flash ROM. This section provides the related specifications.

## ■ Basic Configuration of Serial Programming Connection with MB90F362/T(S), MB90F367/T(S)

Fujitsu standard serial on-board writing uses the Yokogawa Digital Computer Corporation AF220/AF210/AF110 flash microcontroller programmer.

Figure 25.1-1 shows the basic configuration for the example serial programming connection of MB90F362/T(S), MB90F367/T(S).

Figure 25.1-1 Basic Configuration MB90F362/T(S), MB90F367/T(S) Serial Programming Connection



#### Note:

For information on the functions of and operational procedures related to the flash microcontroller programmer (AF220/AF210/AF120/AF110), the general-purpose common cable (AZ210) for connection, and the connector, contact Yokogawa Digital Computer Corporation.

Table 25.1-1 Pin Used for Fujitsu Standard Serial on-board Programming

| Pin                 | Function                      | Additional information                                                                                                                                                                                                                                                           |  |
|---------------------|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| MD2,<br>MD1,<br>MD0 | Mode pins                     | Controls programming mode from the flash microcontroller programmer.                                                                                                                                                                                                             |  |
| X0, X1              | Oscillation pins              | In programming mode, the CPU internal operation clock signal is one multiple of the PLL clock signal frequency. Therefore, because the oscillation clock frequency becomes the internal operation clock signal, the oscillator used for serial reprogramming is 4 MHz to 16 MHz. |  |
| P83, P84            | Programming activation pins   | Input "L" level to P83 and "H" level to P84.                                                                                                                                                                                                                                     |  |
| RST                 | Reset pin                     | -                                                                                                                                                                                                                                                                                |  |
| SIN1                | Serial data input pin         |                                                                                                                                                                                                                                                                                  |  |
| SOT1                | Serial data output pin        | Use UART1 as CLK synchronous mode.                                                                                                                                                                                                                                               |  |
| SCK1                | Serial clock signal input pin |                                                                                                                                                                                                                                                                                  |  |
| С                   | C pin                         | This pin is used to stabilize the power supply.  Connect to a external ceramic capacitor of approximately 0.1 µF or more.                                                                                                                                                        |  |
| V <sub>CC</sub>     | Power voltage supply pin      | If the programming voltage (5 V $\pm$ 10%) is supplied from the user system, the flash microcontroller programmer need not be connected. Connect so that the power supply of the user side is not short-circuited.                                                               |  |
| V <sub>SS</sub>     | GND pin                       | Common to the ground of the flash microcontroller programmer.                                                                                                                                                                                                                    |  |

Even if the P83, P84, SIN1, SOT1, and SCK1 pins are used for the user system, the control circuit shown in Figure 25.1-2 is required. (The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.)

Figure 25.1-2 Control Circuit



- "25.2 Example of Serial Programming Connection (User Power Supply Used)" to "25.5 Example of Minimum Connection to Flash Microcontroller Programmer (Power Supplied from Programmer)" present examples the following 4 types of serial programming connection. See each Section as required.
- Example of serial programming connection (user power supply used)
- Example of serial programming connection (power supplied from the programmer)
- Example of minimum connection to the flash microcontroller programmer (user power supply used)
- Example of minimum connection to the flash microcontroller programmer (power supplied from the

programmer)

Table 25.1-2 System Configuration of Flash Microcontroller Programmers (Manufactured by Yokogawa Digital Computer Corporation)

|                                                                | Model                                       | Function                                                                         |  |
|----------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------------------------|--|
| Main AF220/AC4P aF210/AC4P                                     |                                             | Ethernet interface built-in model and 100 V to 220 V AC power adapter            |  |
|                                                                |                                             | Standard model and 100 V to 220 V AC power adapter                               |  |
|                                                                | AF120/AC4P                                  | Single-key Ethernet interface built-in model and 100 V to 220 V AC power adapter |  |
|                                                                | AF110/AC4P                                  | Single-key model and 100 V to 220 V AC power adapter                             |  |
| AZ221                                                          |                                             | RS232C cable for programmer PC/AT                                                |  |
| AZ210                                                          | Standard target probe (a) cable length: 1 m |                                                                                  |  |
| FF201                                                          |                                             | Fujitsu F <sup>2</sup> MC-16LX flash microcontroller control module              |  |
| AZ290                                                          |                                             | Remote controller                                                                |  |
| /P2 2MB PC Card (optional) for flash memory sizes up to 128 KB |                                             | 2MB PC Card (optional) for flash memory sizes up to 128 KB                       |  |
| /P4                                                            |                                             | 4MB PC Card (optional) for flash memory sizes up to 512 KB                       |  |

Inquiries: Yokogawa Digital Computer Corporation

Telephone number: (81)-42-333-6224

#### Note:

Although the AF200 flash microcontroller programmer is no longer manufactured, the programmer still can be used in combination with the FF201 control module.

Examples of serial programming connection can correspond to the connection example as shown in "Coscillating Clock Frequency and Serial Clock Input Frequency".

# ■ Oscillating Clock Frequency and Serial Clock Input Frequency

The equation listed below can be used to calculate the serial clock frequencies that can be used for the MB90F362/T(S), MB90F367/T(S).

Serial clock frequency that can be input = 0.125 \* example of oscillation clock frequency

Set an appropriate serial clock input frequency in the flash microcontroller programmer according to the oscillating clock frequency in use.

Table 25.1-3 Examples of Serial Clock Frequencies that can be Input

| Oscillating clock frequency | Maximum serial clock frequency that can be input for microcontrollers | Maximum serial clock<br>frequency that can be used for<br>the AF220, AF210, AF120 and<br>AF110 | Maximum serial clock<br>frequency that can be used for<br>the AF200 |
|-----------------------------|-----------------------------------------------------------------------|------------------------------------------------------------------------------------------------|---------------------------------------------------------------------|
| 4 MHz                       | 500 kHz                                                               | 500 kHz                                                                                        | 500 kHz                                                             |
| 8 MHz                       | 1 MHz                                                                 | 850 kHz                                                                                        | 500 kHz                                                             |
| 16 MHz                      | 2 MHz                                                                 | 1.25 MHz                                                                                       | 500 kHz                                                             |

# 25.2 Example of Serial Programming Connection (User Power Supply Used)

Figure 25.2-1 shows an example of a serial programming connection when the user power supply is used. The value 1 and 0 are input to mode pins MD2 and MD0 from TAUX3 and TMODE of the AF220/AF210/AF120/AF110 programmer.

Serial reprogramming mode: MD2, MD1, MD0 = 110.

# **■** Example of Serial Programming Connection (User power supply used)

Figure 25.2-1 Example of Serial Programming Connection for MB90F362/T(S), MB90F367/T(S) Single-chip Modes (User power supply Used)



• Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the control circuit shown in the figure below is required in the same way that it is for P83. (The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.)

Figure 25.2-2 Control Circuit



• Connect the AF220/AF210/AF120/AF110 while the user power is off.

# 25.3 Example of Serial Programming Connection (Power Supplied from Programmer)

Figure 25.3-1 shows an example of a serial programming connection when power is supplied from the programmer. The value 1 and 0 are input to mode pins MD2 and MD0 from TAUX3 and TMODE of the AF220/AF210/AF120/AF110 programmer.

Serial reprogramming mode: MD2, MD1, MD0 = 110.

# **■** Example of Serial Programming Connection (Power supplied from programmer)

Figure 25.3-1 Example of Serial Programming Connection for MB90F362/T(S), MB90F367/T(S) Single-chip Modes (Power supplied from programmer)



• Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the control circuit shown in the figure below is required in the same way that it is for P83. (The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.)

AF220/AF210/AF120/AF110
write control pin

MB90F362/T(S),
MB90F367/T(S)

AF220/AF210/AF120/AF110

Write control pin

/TICS pin

User

Figure 25.3-2 Control Circuit

- Connect the AF220/AF210/AF120/AF110 while the user power is off.
- When the programming power is supplied from the AF220/AF210/AF120/AF110, be careful not to short-circuit the user power supply.

# 25.4 Example of Minimum Connection to Flash Microcontroller Programmer (User Power Supply Used)

Figure 25.4-1 shows an example of the minimum connection to the flash microcontroller programmer when the user power supply is used.

Serial reprogramming mode: MD2, MD1, MD0 = 110.

## ■ Example of Minimum Connection to Flash Microcontroller Programmer (User power supply used)

For a flash memory write, the MD2, MD1, MD0, P83, and P84 pins and flash microcontroller programmer need not be connected if the pins are set as Figure 25.4-1.

Figure 25.4-1 Example of Minimum Connection to MB90F362/T(S), MB90F367/T(S) Flash Microcontroller Programmer (User power supply Used)



• Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the control circuit shown in the figure below is required. (The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.)

Figure 25.4-2 Control Circuit



• Connect the AF220/AF210/AF120/AF110 while the user power is off.

# 25.5 Example of Minimum Connection to Flash Microcontroller Programmer (Power Supplied from Programmer)

Figure 25.5-1 shows an example of the minimum connection to the MB90F362/T(S), MB90F367/T(S) flash microcontroller programmer when power is supplied from the Programmer.

Serial reprogramming mode: MD2, MD1, MD0 = 110<sub>B</sub>.

## ■ Example of Minimum Connection to Flash Microcomputer Programmer (Power supplied from programmer)

For a flash memory write, the MD2, MD1, MD0, P83, and P84 pins and flash microcontroller programmer need not be connected if the pins are set as Figure 25.5-1.

MB90F362/T(S), AF220/AF210/AF120/AF110 MB90F367/T(S) User system flash microcontroller programmer MD2 1 for serial rewrite MD1  $10 k \Omega$ 4MHz to 16MHz P83 0 for serial rewrite User circuit P84 1 for serial rewrite User circuit Connector 売<sup>0.1μF</sup> DX10-28S DX20-28S  $10k\Omega$ (5) RST /TRFS TTXD (13)TRXD (27)SOT1 TCK (6) SCK1 TVcc Vcc TVPP1 (2) (3) (16) Vcc **GND** Vss - 4,9,10,11,12,17,18,19,20,23,24,25 and 26 DX10-28S pins are open. DX20-28S - DX10-28S : Right-angle type - DX20-28S : Straight type 28 pin Connector (Hirose Electronics Ltd.) pin arrangement

Figure 25.5-1 Example of Minimum Connection to the MB90F362/T(S), MB90F367/T(S) Flash Microcontroller Programmer (power supplied from programmer)

• Even if the SIN1, SOT1, and SCK1 pins are used for the user system, the control circuit shown in the figure below is required. (The /TICS signal of the flash microcontroller programmer can be used to disconnect the user circuit during serial programming.)

Figure 25.5-2 Control Circuit



- Connect the AF220/AF210/AF120/AF110 while the user power is off.
- When the programming power is supplied from the AF220/AF210/AF120/AF110, be careful not to short-circuit the user power supply.

## **CHAPTER 26**

## ROM SECURITY FUNCTION

This chapter explains the ROM security function.

26.1 Overview of ROM Security Function

## 26.1 Overview of ROM Security Function

#### The ROM security function protects the content of ROM.

#### **■** Overview of ROM Security Function

The ROM security function is a function to prevent ROM data being read to the third party by limiting the access to ROM.

Please contact to Fujitsu about details of this function.

## **APPENDIX**

The appendixes provide I/O maps, instructions, and other information.

APPENDIX A I/O Maps

APPENDIX B Instructions

APPENDIX C Timing Diagrams in Flash Memory Mode

APPENDIX D List of Interrupt Vectors

## APPENDIX A I/O Maps

### Table A-1 lists addresses to be assigned to the registers in the peripheral blocks.

## ■ I/O Maps (00XX Addresses)

Table A-1 I/O Map (1/5)

| Address                                    | Register                     | Abbreviation | Access   | Peripheral  | Initial value                  |  |  |
|--------------------------------------------|------------------------------|--------------|----------|-------------|--------------------------------|--|--|
| 000000 <sub>H</sub> to 000001 <sub>H</sub> | Reserved                     |              |          |             |                                |  |  |
| 000002 <sub>H</sub>                        | Port 2 data register         | PDR2         | R/W      | Port 2      | XXXXXXXX <sub>B</sub>          |  |  |
| 000003 <sub>H</sub>                        | Reserved                     |              |          |             |                                |  |  |
| 000004 <sub>H</sub>                        | Port 4 data register         | PDR4         | R/W      | Port 4      | XXXXXXXX                       |  |  |
| 000005 <sub>H</sub>                        | Port 5 data register         | PDR5         | R/W      | Port 5      | XXXXXXXX <sub>B</sub>          |  |  |
| 000006 <sub>H</sub>                        | Port 6 data register         | PDR6         | R/W      | Port 6      | XXXXXXXX <sub>B</sub>          |  |  |
| 000007 <sub>H</sub>                        | Reserved                     |              |          |             |                                |  |  |
| 000008 <sub>H</sub>                        | Port 8 data register         | PDR8         | R/W      | Port 8      | XXXXXXXX <sub>B</sub>          |  |  |
| 000009 <sub>H</sub> to 00000A <sub>H</sub> | Reserved                     |              |          |             |                                |  |  |
| 00000B <sub>H</sub>                        | Analog input enable port 5   | ADER5        | R/W      | Port 5, A/D | 1111111 <sub>B</sub>           |  |  |
| 00000C <sub>H</sub>                        | Analog input enable port 6   | ADER6        | R/W      | Port 6, A/D | 1 1 1 1 1 1 1 1 <sub>B</sub>   |  |  |
| 00000D <sub>H</sub>                        | Reserved                     | 1            | -        |             |                                |  |  |
| 00000E <sub>H</sub>                        | Input level select register0 | ILSR0        | R/W      | Ports       | XXXXXXXX <sub>B</sub>          |  |  |
| 00000F <sub>H</sub>                        | Input level select register1 | ILSR1        | R/W      | Ports       | XXXXXXXX <sub>B</sub>          |  |  |
| 000010 <sub>H</sub>                        | D1                           | 1            | -        |             |                                |  |  |
| 000011 <sub>H</sub>                        | -Reserved                    |              |          |             |                                |  |  |
| 000012 <sub>H</sub>                        | Port 2 direction register    | DDR2         | R/W      | Port 2      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |
| 000013 <sub>H</sub>                        | Reserved                     | 1            | <u> </u> |             |                                |  |  |
| 000014 <sub>H</sub>                        | Port 4 direction register    | DDR4         | R/W      | Port 4      | XXX 0 0 0 0 0 <sub>B</sub>     |  |  |
| 000015 <sub>H</sub>                        | Port 5 direction register    | DDR5         | R/W      | Port 5      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |
| 000016 <sub>H</sub>                        | Port 6 direction register    | DDR6         | R/W      | Port 6      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |
| 000017 <sub>H</sub>                        | Reserved                     | ı            | 1        |             | '                              |  |  |
| 000018 <sub>H</sub>                        | Port 8 direction register    | DDR8         | R/W      | Port 8      | 0 0 0 0 0 0 X 0 <sub>B</sub>   |  |  |

Table A-1 I/O Map (2/5)

| Address                                    | Register                                  | Abbreviation | Access                         | Peripheral                   | Initial value                  |  |  |  |
|--------------------------------------------|-------------------------------------------|--------------|--------------------------------|------------------------------|--------------------------------|--|--|--|
| 000019 <sub>H</sub>                        | Reserved                                  |              |                                |                              |                                |  |  |  |
| 00001A <sub>H</sub>                        | Port A direction register                 | DDRA         | W                              | Port A                       | XXX0 0XXX <sub>B</sub>         |  |  |  |
| 00001B <sub>H</sub> to 00001D <sub>H</sub> | Reserved                                  |              |                                |                              |                                |  |  |  |
| 00001E <sub>H</sub>                        | Port 2 pull-up control register           | Port 2       | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |                              |                                |  |  |  |
| 00001F <sub>H</sub>                        | Reserved                                  |              |                                |                              | •                              |  |  |  |
| 000020 <sub>H</sub>                        | Serial mode register 0                    | SMR0         | W, R/W                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000021 <sub>H</sub>                        | Serial control register 0                 | SCR0         | W, R/W                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000022 <sub>H</sub>                        | Reception/transmission data register 0    | RDR0/TDR0    | R/W                            |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000023 <sub>H</sub>                        | Serial status register 0                  | SSR0         | R, R/W                         |                              | 0 0 0 0 1 0 0 0 <sub>B</sub>   |  |  |  |
| 000024 <sub>H</sub>                        | Extended communication control register 0 | ECCR0        | R, W, R/W                      | UART0                        | 0 0 0 0 0 0 XX <sub>B</sub>    |  |  |  |
| 000025 <sub>H</sub>                        | Extended status control register0         | ESCR0        | R/W                            |                              | 0 0 0 0 0 1 0 0 <sub>B</sub>   |  |  |  |
| 000026 <sub>H</sub>                        | Baud rate generator register 00           | BGR00        | R/W, R                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000027 <sub>H</sub>                        | Baud rate generator register 01           | BGR01        | R/W, R                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000028 <sub>H</sub>                        | Serial mode register 1                    | SMR1         | W, R/W                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000029 <sub>H</sub>                        | Serial control register 1                 | SCR1         | W, R/W                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 00002A <sub>H</sub>                        | Reception/transmission data register 1    | RDR1/TDR1    | R/W                            |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 00002B <sub>H</sub>                        | Serial status register 1                  | SSR1         | R, R/W                         |                              | 0 0 0 0 1 0 0 0 <sub>B</sub>   |  |  |  |
| 00002C <sub>H</sub>                        | Extended communication control register1  | ECCR1        | R, W, R/W                      | UART1                        | 0 0 0 0 0 0 0 XX <sub>B</sub>  |  |  |  |
| 00002D <sub>H</sub>                        | Extended status control register 1        | ESCR1        | R/W                            |                              | 0 0 0 0 0 1 0 0 <sub>B</sub>   |  |  |  |
| 00002E <sub>H</sub>                        | Baud rate generator register 10           | BGR10        | R/W, R                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 00002F <sub>H</sub>                        | Baud rate generator register 11           | BGR11        | R/W, R                         |                              | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 000030 <sub>H</sub> to 00003A <sub>H</sub> | Reserved                                  |              |                                |                              |                                |  |  |  |
| 00003B <sub>H</sub>                        | Address detection control register 1      | PACSR1       | R/W                            | Address Match<br>Detection 1 | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |  |  |
| 00003C <sub>H</sub> to                     | Reserved                                  |              |                                |                              |                                |  |  |  |
| 000048 <sub>H</sub>                        | PPGC operation mode control register      | PPGCC        | W, R/W                         |                              | 0 X 0 0 0 XX1 <sub>B</sub>     |  |  |  |
| 000049 <sub>H</sub>                        | PPGD operation mode control register      | PPGCD        | W, R/W                         | 16-bit<br>PPGC/D             | 0 X 0 0 0 0 0 1 <sub>B</sub>   |  |  |  |
| 00004A <sub>H</sub>                        | PPGC /D count clock selection register    | PPGCD        | R/W                            | 1130,0                       | 0 0 0 0 0 0 X 0 <sub>B</sub>   |  |  |  |

Table A-1 I/O Map (3/5)

| Address                                    | Register                                                              | Abbreviation | Access | Peripheral                                         | Initial value                  |  |
|--------------------------------------------|-----------------------------------------------------------------------|--------------|--------|----------------------------------------------------|--------------------------------|--|
| 00004B <sub>H</sub>                        | Reserved                                                              |              |        |                                                    |                                |  |
| 00004C <sub>H</sub>                        | PPGE operation mode control register                                  | PPGCE        | W, R/W |                                                    | 0 X 0 0 0 XX1 <sub>B</sub>     |  |
| 00004D <sub>H</sub>                        | PPGF operation mode control register                                  | PPGCF        | W, R/W | 16-bit<br>PPGE/F                                   | 0 X 0 0 0 0 0 1 <sub>B</sub>   |  |
| 00004E <sub>H</sub>                        | PPGE/F count clock selection register                                 | PPGEF        | R/W    |                                                    | 0 0 0 0 0 0 X 0 <sub>B</sub>   |  |
| 00004F <sub>H</sub>                        | Reserved                                                              |              |        |                                                    |                                |  |
| 000050 <sub>H</sub>                        | Input capture control status 0/1                                      | ICS01        | R/W    | Innut Contugo 0/1                                  | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 000051 <sub>H</sub>                        | Input capture edge 0/1                                                | ICE01        | R/W, R | Input Capture 0/1                                  | XXX0X0XX <sub>B</sub>          |  |
| 000052 <sub>H</sub>                        | Input capture control status 2/3                                      | ICS23        | R/W    | Lauret Cantana 2/2                                 | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 000053 <sub>H</sub>                        | Input capture edge 2/3                                                | ICE23        | R      | Input Capture 2/3                                  | XXXXXXXX <sub>B</sub>          |  |
| 000054 <sub>H</sub> to 000063 <sub>H</sub> | Reserved                                                              |              |        |                                                    |                                |  |
| 000064 <sub>H</sub>                        | Timer control status 2                                                | TMCSR2       | R/W    | 16-bit Reload Timer                                | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 000065 <sub>H</sub>                        | Timer control status 2                                                | TMCSR2       | R/W    | 2                                                  | XXXX 0 0 0 0 <sub>B</sub>      |  |
| 000066 <sub>H</sub>                        | Timer control status 3                                                | TMCSR3       | R/W    | 16-bit Reload Timer                                | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 000067 <sub>H</sub>                        | Timer control status 3                                                | TMCSR3       | R/W    | 3                                                  | XXXX 0 0 0 0 <sub>B</sub>      |  |
| 000068 <sub>H</sub>                        | A/D control status 0                                                  | ADCS0        | R/W    |                                                    | 0 0 0 XXXX 0 <sub>B</sub>      |  |
| 000069 <sub>H</sub>                        | A/D control status 1                                                  | ADCS1        | R/W, W |                                                    | 0 0 0 0 0 0 0 X <sub>B</sub>   |  |
| 00006A <sub>H</sub>                        | A/D data 0                                                            | ADCR0        | R      | A/D Commenter                                      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 00006B <sub>H</sub>                        | A/D data 1                                                            | ADCR1        | R      | A/D Converter                                      | XXXXXX 0 0 <sub>B</sub>        |  |
| 00006C <sub>H</sub>                        | ADC setting 0                                                         | ADSR0        | R/W    |                                                    | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 00006D <sub>H</sub>                        | ADC setting 1                                                         | ADSR1        | R/W    |                                                    | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |
| 00006E <sub>H</sub>                        | Detection reset control register of low-voltage/CPU operation         | LVRC         | R/W, W | Detection Reset of<br>Low-voltage/CPU<br>Operation | 0 0 1 1 1 0 0 0 <sub>B</sub>   |  |
| 00006F <sub>H</sub>                        | ROM mirror function select                                            | ROMM         | W      | ROM Mirror                                         | XXXXXXX1 <sub>B</sub>          |  |
| 000070 <sub>H</sub> to                     | Reserved                                                              |              |        |                                                    |                                |  |
| 000080 <sub>H</sub> to                     | Reserved for CAN interface. (For more information, see Table 21.3-1.) |              |        |                                                    |                                |  |
| 000090 <sub>H</sub> to                     | Reserved                                                              |              |        |                                                    |                                |  |
| 00009E <sub>H</sub>                        | Address detection control register0                                   | PACSR0       | R/W    | Address Match<br>Detection 0                       | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |  |

Table A-1 I/O Map (4/5)

| Address                                       | Register                                     | Abbreviation | Access | Peripheral                             | Initial value                |
|-----------------------------------------------|----------------------------------------------|--------------|--------|----------------------------------------|------------------------------|
| 00009F <sub>H</sub>                           | Delayed interrupt/release register           | DIRR         | R/W    | Delayed Interrupt<br>Generation Module | XXXXXXX0 <sub>B</sub>        |
| 0000A0 <sub>H</sub>                           | Low-power mode control register              | LPMCR        | W, R/W | Low Power<br>Controller                | 0 0 0 1 1 0 0 0 <sub>B</sub> |
| 0000A1 <sub>H</sub>                           | Clock selection register                     | CKSCR        | R, R/W | Low Power<br>Controller                | 1 1 1 1 1 1 0 0 <sub>B</sub> |
| 0000A2 <sub>H</sub> to<br>0000A7 <sub>H</sub> | Reserved                                     |              |        |                                        |                              |
| 0000A8 <sub>H</sub>                           | Watchdog timer control register              | WDTC         | R, W   | Watchdog Timer                         | XXXXX111 <sub>B</sub>        |
| 0000A9 <sub>H</sub>                           | Time base timer control register             | TBTC         | W, R/W | Time Base Timer                        | 1 XX 0 0 1 0 0 <sub>B</sub>  |
| 0000AA <sub>H</sub>                           | Watch timer control register                 | WTC          | R, R/W | Watch Timer                            | 1 X 0 0 1 0 0 0 <sub>B</sub> |
| 0000AB <sub>H</sub> to                        | Reserved                                     |              |        |                                        |                              |
| 0000AE <sub>H</sub>                           | Flash control status<br>(Flash device only.) | FMCS         | R, R/W | Flash Memory                           | 0 0 0 X 0 0 0 0 <sub>B</sub> |
| 0000AF <sub>H</sub>                           | Reserved                                     | -1           | •      |                                        |                              |
| 0000B0 <sub>H</sub>                           | Interrupt control register 00                | ICR00        | W, R/W |                                        | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B1 <sub>H</sub>                           | Interrupt control register 01                | ICR01        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B2 <sub>H</sub>                           | Interrupt control register 02                | ICR02        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B3 <sub>H</sub>                           | Interrupt control register 03                | ICR03        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B4 <sub>H</sub>                           | Interrupt control register 04                | ICR04        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B5 <sub>H</sub>                           | Interrupt control register 05                | ICR05        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B6 <sub>H</sub>                           | Interrupt control register 06                | ICR06        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B7 <sub>H</sub>                           | Interrupt control register 07                | ICR07        | W, R/W | Later and Constantillan                | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B8 <sub>H</sub>                           | Interrupt control register 08                | ICR08        | W, R/W | Interrupt Controller                   | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000B9 <sub>H</sub>                           | Interrupt control register 09                | ICR09        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BA <sub>H</sub>                           | Interrupt control register 10                | ICR10        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BB <sub>H</sub>                           | Interrupt control register 11                | ICR11        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BC <sub>H</sub>                           | Interrupt control register 12                | ICR12        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BD <sub>H</sub>                           | Interrupt control register 13                | ICR13        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BE <sub>H</sub>                           | Interrupt control register 14                | ICR14        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000BF <sub>H</sub>                           | Interrupt control register 15                | ICR15        | W, R/W | 1                                      | 0 0 0 0 0 1 1 1 <sub>B</sub> |
| 0000C0 <sub>H</sub> to                        | Reserved                                     |              |        |                                        | ,<br>                        |

Table A-1 I/O Map (5/5)

| Address                                    | Register                           | Abbreviation | Access | Peripheral           | Initial value                  |
|--------------------------------------------|------------------------------------|--------------|--------|----------------------|--------------------------------|
| 0000CA <sub>H</sub>                        | External interrupt enable 1        | ENIR1        | R/W    |                      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 0000CB <sub>H</sub>                        | External interrupt request 1       | EIRR1        | R/W    |                      | XXXXXXXX <sub>B</sub>          |
| 0000CC <sub>H</sub>                        | External interrupt level 1         | ELVR1        | R/W    | External Interrupt 1 | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 0000CD <sub>H</sub>                        | External interrupt level 1         | ELVR1        | R/W    |                      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 0000CE <sub>H</sub>                        | External interrupt 1 source select | EISSR        | R/W    |                      | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 0000CF <sub>H</sub>                        | PLL/subclock control register      | PSCCR        | W      | PLL                  | XXXX 0 0 0 0 0 <sub>B</sub>    |
| 0000D0 <sub>H</sub> to 0000FF <sub>H</sub> | Reserved                           | •            |        |                      |                                |

## ■ I/O map (79XX - 7FXX addresses)

Table A-2 I/O Map (7900<sub>H</sub> - 7FFF<sub>H</sub>) (1/3)

| Address                                   | Register           | Abbreviation | Access | Peripheral        | Initial value                  |
|-------------------------------------------|--------------------|--------------|--------|-------------------|--------------------------------|
| 7900 <sub>H</sub> to 7917 <sub>H</sub>    | Reserved           | •            |        |                   |                                |
| 7918 <sub>H</sub>                         | Reload register LC | PRLLC        | R/W    |                   | XXXXXXXX <sub>B</sub>          |
| 7919 <sub>H</sub>                         | Reload register HC | PRLHC        | R/W    | 16-bit            | XXXXXXXX <sub>B</sub>          |
| 791A <sub>H</sub>                         | Reload register LD | PRLLD        | R/W    | PPG C/D           | XXXXXXXX <sub>B</sub>          |
| 791B <sub>H</sub>                         | Reload register HD | PRLHD        | R/W    |                   | XXXXXXXX <sub>B</sub>          |
| 791C <sub>H</sub>                         | Reload register LE | PRLLE        | R/W    |                   | XXXXXXXX <sub>B</sub>          |
| 791D <sub>H</sub>                         | Reload register HE | PRLHE        | R/W    | 16-bit            | XXXXXXXX <sub>B</sub>          |
| 791E <sub>H</sub>                         | Reload register LF | PRLLF        | R/W    | PPG E/F           | XXXXXXXX <sub>B</sub>          |
| 791F <sub>H</sub>                         | Reload register HF | PRLHF        | R/W    |                   | XXXXXXXX <sub>B</sub>          |
| 7920 <sub>H</sub>                         | Input capture 0    | IPCP0        | R      |                   | XXXXXXXX <sub>B</sub>          |
| 7921 <sub>H</sub>                         | Input capture 0    | IPCP0        | R      | T . C . 0/1       | XXXXXXXX <sub>B</sub>          |
| 7922 <sub>H</sub>                         | Input capture 1    | IPCP1        | R      | Input Capture 0/1 | XXXXXXXX <sub>B</sub>          |
| 7923 <sub>H</sub>                         | Input capture 1    | IPCP1        | R      |                   | XXXXXXXX <sub>B</sub>          |
| 7924 <sub>H</sub>                         | Input capture 2    | IPCP2        | R      |                   | XXXXXXXX <sub>B</sub>          |
| 7925 <sub>H</sub>                         | Input capture 2    | IPCP2        | R      | Land Card and 2/2 | XXXXXXXX <sub>B</sub>          |
| 7926 <sub>H</sub>                         | Input capture 3    | IPCP3        | R      | Input Capture 2/3 | XXXXXXXX <sub>B</sub>          |
| 7927 <sub>H</sub>                         | Input capture 3    | IPCP3        | R      |                   | XXXXXXXX <sub>B</sub>          |
| 7928 <sub>H</sub> to<br>793F <sub>H</sub> | Reserved           | '            |        |                   |                                |
| 7940 <sub>H</sub>                         | Timer data 0       | TCDT0        | R/W    |                   | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 7941 <sub>H</sub>                         | Timer data 0       | TCDT0        | R/W    | L/O TT            | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 7942 <sub>H</sub>                         | Timer control 0    | TCCSL0       | R/W    | I/O Timer 0       | 0 0 0 0 0 0 0 0 0 <sub>B</sub> |
| 7943 <sub>H</sub>                         | Timer control 0    | TCCSH0       | R/W    |                   | 0XXXXXXX <sub>B</sub>          |
| 7944 <sub>H</sub> to<br>794B <sub>H</sub> | Reserved           |              |        |                   |                                |
| 794C <sub>H</sub>                         | TT: 2/ 1 12        | TMR2/        | R, W   | 16-bit Reload     | XXXXXXXX <sub>B</sub>          |
| 794D <sub>H</sub>                         | Timer 2/reload 2   | TMRLR2       | R, W   | Timer 2           | XXXXXXXX <sub>B</sub>          |
| 794E <sub>H</sub>                         | Tr. 2/ 1 12        | TMR3/        | R, W   | 16-bit Reload     | XXXXXXXX <sub>B</sub>          |
| 794F <sub>H</sub>                         | Timer 3/reload 3   | TMRLR3       | R, W   | Timer 3           | XXXXXXXX <sub>B</sub>          |

Table A-2 I/O Map (7900<sub>H</sub> - 7FFF<sub>H</sub>) (2/3)

| Address                                   | Register                                        | Abbreviation      | Access          | Peripheral                | Initial value                |  |  |  |
|-------------------------------------------|-------------------------------------------------|-------------------|-----------------|---------------------------|------------------------------|--|--|--|
| 7950 <sub>H</sub> to<br>795F <sub>H</sub> | Reserved                                        |                   |                 |                           |                              |  |  |  |
| 7960 <sub>H</sub>                         | Clock supervisor control register               | CSVCR             | R, R/W          | Clock supervisor          | 0 0 0 1 1 1 0 0 <sub>B</sub> |  |  |  |
| 7961 <sub>H</sub> to<br>796D <sub>H</sub> | Reserved                                        |                   |                 |                           |                              |  |  |  |
| 796E <sub>H</sub>                         | CAN direct mode register<br>(For only MB90V340) | CDMR              | R/W             | CAN Clock Sync            | XXXXXXX0B                    |  |  |  |
| 796F <sub>H</sub> to<br>79DF <sub>H</sub> | Reserved                                        |                   |                 |                           |                              |  |  |  |
| 79E0 <sub>H</sub>                         | Detection address setting 0                     | PADR0             | R/W             |                           | XXXXXXXX                     |  |  |  |
| 79E1 <sub>H</sub>                         | Detection address setting 0                     | PADR0             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E2 <sub>H</sub>                         | Detection address setting 0                     | PADR0             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E3 <sub>H</sub>                         | Detection address setting 1                     | PADR1             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E4 <sub>H</sub>                         | Detection address setting 1                     | PADR1             | R/W             | Address Match Detection 0 | XXXXXXXX                     |  |  |  |
| 79E5 <sub>H</sub>                         | Detection address setting 1                     | PADR1             | R/W             | Detection o               | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E6 <sub>H</sub>                         | Detection address setting 2                     | PADR2             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E7 <sub>H</sub>                         | Detection address setting 2                     | PADR2             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E8 <sub>H</sub>                         | Detection address setting 2                     | PADR2             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79E9 <sub>H</sub> to<br>79EF <sub>H</sub> | Reserved                                        | ,                 |                 |                           |                              |  |  |  |
| 79F0 <sub>H</sub>                         | Detection address setting 3                     | PADR3             | R/W             |                           | XXXXXXXX                     |  |  |  |
| 79F1 <sub>H</sub>                         | Detection address setting 3                     | PADR3             | R/W             |                           | XXXXXXXX                     |  |  |  |
| 79F2 <sub>H</sub>                         | Detection address setting 3                     | PADR3             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F3 <sub>H</sub>                         | Detection address setting 4                     | PADR4             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F4 <sub>H</sub>                         | Detection address setting 4                     | PADR4             | R/W             | Address Match Detection 1 | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F5 <sub>H</sub>                         | Detection address setting 4                     | PADR4             | R/W             | Bettetion 1               | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F6 <sub>H</sub>                         | Detection address setting 5                     | PADR5             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F7 <sub>H</sub>                         | Detection address setting 5                     | PADR5             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F8 <sub>H</sub>                         | Detection address setting 5                     | PADR5             | R/W             |                           | XXXXXXXX <sub>B</sub>        |  |  |  |
| 79F9 <sub>H</sub> to<br>7BFF <sub>H</sub> | Reserved                                        | 1                 |                 |                           | -                            |  |  |  |
| 7C00 <sub>H</sub> to<br>7CFF <sub>H</sub> | Reserved for CAN interface 1. (Fo               | r more informatio | on, see Table 2 | 1.3-1 .)                  |                              |  |  |  |

### Table A-2 I/O Map $(7900_H - 7FFF_H)$ (3/3)

| Address                                   | Register                                                                | Abbreviation | Access | Peripheral | Initial value |  |
|-------------------------------------------|-------------------------------------------------------------------------|--------------|--------|------------|---------------|--|
| 7D00 <sub>H</sub> to<br>7DFF <sub>H</sub> | Reserved for CAN interface 1. (For more information, see Table 21.3-2.) |              |        |            |               |  |
| 7E00 <sub>H</sub> to<br>7FFF <sub>H</sub> | Reserved                                                                |              |        |            |               |  |

#### Note:

Any write access to reserved addresses in I/O map should not be performed. A read access to reserved address results in reading "X".

#### Explanation of write and read

R/W: Both read and write enabled

R: Only read enabled W: Only write enabled

#### Explanation of initial values

0: The initial value of this bit is "0".

1: The initial value of this bit is "1".

X: The initial value of this bit is undefined.

## **APPENDIX B** Instructions

## Appendix B describes the instructions used by the F<sup>2</sup>MC-16LX.

- **B.1 Instruction Types**
- B.2 Addressing
- B.3 Direct Addressing
- **B.4 Indirect Addressing**
- **B.5 Execution Cycle Count**
- B.6 Effective address field
- B.7 How to Read the Instruction List
- B.8 F<sup>2</sup>MC-16LX Instruction List
- B.9 Instruction Map

## **B.1 Instruction Types**

The  $F^2MC$ -16LX supports 351 types of instructions. Addressing is enabled by using an effective address field of each instruction or using the instruction code itself.

#### **■** Instruction Types

The F<sup>2</sup>MC-16LX supports the following 351 types of instructions:

- 41 transfer instructions (byte)
- 38 transfer instructions (word or long word)
- 42 addition/subtraction instructions (byte, word, or long word)
- 12 increment/decrement instructions (byte, word, or long word)
- 11 comparison instructions (byte, word, or long word)
- 11 unsigned multiplication/division instructions (word or long word)
- 11 signed multiplication/division instructions (word or long word)
- 39 logic instructions (byte or word)
- 6 logic instructions (long word)
- 6 sign inversion instructions (byte or word)
- 1 normalization instruction (long word)
- 18 shift instructions (byte, word, or long word)
- 50 branch instructions
- 6 accumulator operation instructions (byte or word)
- 28 other control instructions (byte, word, or long word)
- 21 bit operation instructions
- 10 string instructions

## **B.2** Addressing

With the F<sup>2</sup>MC-16LX, the address format is determined by the instruction effective address field or the instruction code itself (implied). When the address format is determined by the instruction code itself, specify an address in accordance with the instruction code used. Some instructions permit the user to select several types of addressing.

#### Addressing

The F<sup>2</sup>MC-16LX supports the following 23 types of addressing:

- Immediate (#imm)
- Register direct
- Direct branch address (addr16)
- Physical direct branch address (addr24)
- I/O direct (io)
- Abbreviated direct address (dir)
- Direct address (addr16)
- I/O direct bit address (io:bp)
- Abbreviated direct bit address (dir:bp)
- Direct bit address (addr16:bp)
- Vector address (#vct)
- Register indirect (@RWj j = 0 to 3)
- Register indirect with post increment (@RWj+ j = 0 to 3)
- Register indirect with displacement (@RWi + disp8 i = 0 to 7, @RWj + disp16 j = 0 to 3)
- Long register indirect with displacement (@RLi + disp8 i = 0 to 3)
- Program counter indirect with displacement (@PC + disp16)
- Register indirect with base index (@RW0 + RW7, @RW1 + RW7)
- Program counter relative branch address (rel)
- Register list (rlst)
- Accumulator indirect (@A)
- Accumulator indirect branch address (@A)
- Indirectly-specified branch address (@ear)
- Indirectly-specified branch address (@eam)

### **■** Effective Address Field

Table B.2-1 lists the address formats specified by the effective address field.

Table B.2-1 Effective Address Field

| Code | F              | Representat | ion   | Address format                                                            | Default bank |
|------|----------------|-------------|-------|---------------------------------------------------------------------------|--------------|
| 00   | R0             | RW0         | RL0   |                                                                           |              |
| 01   | R1             | RW1         | (RL0) |                                                                           |              |
| 02   | R2             | RW2         | RL1   |                                                                           |              |
| 03   | R3             | RW3         | (RL1) | Register direct: Individual parts                                         | None         |
| 04   | R4             | RW4         | RL2   | correspond to the byte, word, and long word types in order from the left. | None         |
| 05   | R5             | RW5         | (RL2) | 71                                                                        |              |
| 06   | R6             | RW6         | RL3   |                                                                           |              |
| 07   | R7             | RW7         | (RL3) |                                                                           |              |
| 08   | @RW0           |             |       |                                                                           | DTB          |
| 09   | @RW1           |             |       | Postar in Face                                                            | DTB          |
| 0A   | @RW2           |             |       | Register indirect                                                         | ADB          |
| 0B   | @RW3           |             |       |                                                                           | SPB          |
| 0C   | @RW0+          |             |       |                                                                           | DTB          |
| 0D   | @RW1+          | @RW1+       |       | Register indirect with post increment                                     | DTB          |
| 0E   | @RW2+<br>@RW3+ |             |       |                                                                           | ADB          |
| 0F   |                |             |       |                                                                           | SPB          |
| 10   | @RW0+disp8     |             |       |                                                                           | DTB          |
| 11   | @RW1+          | disp8       |       | Register indirect with 8-bit displacement                                 | DTB          |
| 12   | @RW2+          | disp8       |       |                                                                           | ADB          |
| 13   | @RW3+          | disp8       |       |                                                                           | SPB          |
| 14   | @RW4+          | disp8       |       |                                                                           | DTB          |
| 15   | @RW5+          | disp8       |       | Desire in France 2d O Lie Frank                                           | DTB          |
| 16   | @RW6+          | disp8       |       | Register indirect with 8-bit displacement                                 | ADB          |
| 17   | @RW7+          | disp8       |       |                                                                           | SPB          |
| 18   | @RW0+          | disp16      |       |                                                                           | DTB          |
| 19   | @RW1+          | disp16      |       | Register indirect with 16-bit                                             | DTB          |
| 1A   | @RW2+          | disp16      |       | displacement                                                              | ADB          |
| 1B   | @RW3+disp16    |             |       |                                                                           | SPB          |
| 1C   | @RW0+RW7       |             |       | Register indirect with index                                              | DTB          |
| 1D   | @RW1+RW7       |             |       | Register indirect with index                                              | DTB          |
| 1E   | @PC+di         | sp16        |       | PC indirect with 16-bit displacement                                      | PCB          |
| 1F   | addr16         |             |       | Direct address                                                            | DTB          |

## **B.3** Direct Addressing

An operand value, register, or address is specified explicitly in direct addressing mode.

#### **■** Direct Addressing

Immediate addressing (#imm)

Specify an operand value explicitly (#imm4/#imm8/#imm16/#imm32).

Figure B.3-1 Example of Immediate Addressing (#imm)

MOVW A, #01212H (This instruction stores the operand value in A.)

Before execution A 2233 4455

After execution A 4455 1212 (Some instructions transfer AL to AH.)

#### Register direct addressing

Specify a register explicitly as an operand. Table B.3-1 lists the registers that can be specified. Figure B.3-2 shows an example of register direct addressing.

Table B.3-1 Direct Addressing Registers

|                          | Byte        | R0, R1, R2, R3, R4, R5, R6, R7         |
|--------------------------|-------------|----------------------------------------|
| General-purpose register | Word        | RW0, RW1, RW2, RW3, RW4, R5W, RW6, RW7 |
|                          | Long word   | RL0, RL1, RL2, RL3                     |
|                          | Accumulator | A, AL                                  |
|                          | Pointer     | SP *                                   |
| Special-purpose register | Bank        | PCB, DTB, USB, SSB, ADB                |
|                          | Page        | DPR                                    |
|                          | Control     | PS, CCR, RP, ILM                       |

<sup>\*:</sup> One of the user stack pointer (USP) and system stack pointer (SSP) is selected and used depending on the value of the S flag bit in the condition code register (CCR). For branch instructions, the program counter (PC) is not specified in an instruction operand but is specified implicitly.

Figure B.3-2 Example of Register Direct Addressing



#### Direct branch addressing (addr16)

Specify an offset explicitly for the branch destination address. The size of the offset is 16 bits, which indicates the branch destination in the logical address space. Direct branch addressing is used for an unconditional branch, subroutine call, or software interrupt instruction. Bits 23 to 16 of the address are specified by the program bank register (PCB).

Figure B.3-3 Example of Direct Branch Addressing (addr16)



#### Physical direct branch addressing (addr24)

Specify an offset explicitly for the branch destination address. The size of the offset is 24 bits. Physical direct branch addressing is used for unconditional branch, subroutine call, or software interrupt instruction.

Figure B.3-4 Example of Direct Branch Addressing (addr24)



#### I/O direct addressing (io)

Specify an 8-bit offset explicitly for the memory address in an operand. The I/O address space in the physical address space from 000000H to 0000FFH is accessed regardless of the data bank register (DTB) and direct page register (DPR). A bank select prefix for bank addressing is invalid if specified before an instruction using I/O direct addressing.

Figure B.3-5 Example of I/O Direct Addressing (io)



#### Abbreviated direct addressing (dir)

Specify the eight low-order bits of a memory address explicitly in an operand. Address bits 8 to 15 are specified by the direct page register (DPR). Address bits 16 to 23 are specified by the data bank register (DTB).

Figure B.3-6 Example of Abbreviated Direct Addressing (dir)



#### Direct addressing (addr16)

Specify the 16 low-order bits of a memory address explicitly in an operand. Address bits 16 to 23 are specified by the data bank register (DTB). A prefix instruction for access space addressing is invalid for this mode of addressing.

Figure B.3-7 Example of Direct Addressing (addr16)



#### I/O direct bit addressing (io:bp)

Specify bits in physical addresses  $000000_H$  to  $0000FF_H$  explicitly. Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).

Figure B.3-8 Example of I/O Direct Bit Addressing (io:bp)



#### Abbreviated direct bit addressing (dir:bp)

Specify the eight low-order bits of a memory address explicitly in an operand. Address bits 8 to 15 are specified by the direct page register (DPR). Address bits 16 to 23 are specified by the data bank register (DTB). Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).

Figure B.3-9 Example of Abbreviated Direct Bit Addressing (dir:bp)



#### Direct bit addressing (addr16:bp)

Specify arbitrary bits in 64K bytes explicitly. Address bits 16 to 23 are specified by the data bank register (DTB). Bit positions are indicated by ":bp", where the larger number indicates the most significant bit (MSB) and the lower number indicates the least significant bit (LSB).

Figure B.3-10 Example of Direct Bit Addressing (addr16:bp)



#### Vector Addressing (#vct)

Specify vector data in an operand to indicate the branch destination address. There are two sizes for vector numbers: 4 bits and 8 bits. Vector addressing is used for a subroutine call or software interrupt instruction.

Figure B.3-11 Example of Vector Addressing (#vct)



Table B.3-2 CALLV Vector List

| Instruction | Vector address L    | Vector address H    |
|-------------|---------------------|---------------------|
| CALLV #0    | XXFFFE <sub>H</sub> | XXFFFF <sub>H</sub> |
| CALLV #1    | XXFFFC <sub>H</sub> | XXFFFD <sub>H</sub> |
| CALLV #2    | XXFFFA <sub>H</sub> | XXFFFB <sub>H</sub> |
| CALLV #3    | XXFFF8 <sub>H</sub> | XXFFF9 <sub>H</sub> |
| CALLV #4    | XXFFF6 <sub>H</sub> | XXFFF7 <sub>H</sub> |
| CALLV #5    | XXFFF4 <sub>H</sub> | XXFFF5 <sub>H</sub> |
| CALLV #6    | XXFFF2 <sub>H</sub> | XXFFF3 <sub>H</sub> |
| CALLV #7    | XXFFF0 <sub>H</sub> | XXFFF1 <sub>H</sub> |
| CALLV #8    | XXFFEE <sub>H</sub> | XXFFEF <sub>H</sub> |
| CALLV #9    | XXFFEC <sub>H</sub> | XXFFED <sub>H</sub> |
| CALLV #10   | XXFFEA <sub>H</sub> | XXFFEB <sub>H</sub> |
| CALLV #11   | XXFFE8 <sub>H</sub> | XXFFE9 <sub>H</sub> |
| CALLV #12   | XXFFE6 <sub>H</sub> | XXFFE7 <sub>H</sub> |
| CALLV #13   | XXFFE4 <sub>H</sub> | XXFFE5 <sub>H</sub> |
| CALLV #14   | XXFFE2 <sub>H</sub> | XXFFE3 <sub>H</sub> |
| CALLV #15   | XXFFE0 <sub>H</sub> | XXFFE1 <sub>H</sub> |

Note: A PCB register value is set in XX.

#### Note:

When the program bank register (PCB) is  $FF_H$ , the vector area overlaps the vector area of INT #vct8 (#0 to #7). Use vector addressing carefully (see Table B.3-2).

## **B.4** Indirect Addressing

In indirect addressing mode, an address is specified indirectly by the address data of an operand.

#### ■ Indirect Addressing

■ Register indirect addressing (@RWj j = 0 to 3)

Memory is accessed using the contents of general-purpose register RWj as an address. Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0 or RW1 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 is used, or additional data bank register (ADB) when RW2 is used.

Figure B.4-1 Example of Register Indirect Addressing (@RWj j = 0 to 3)



Register indirect addressing with post increment (@RWj+ j = 0 to 3)

Memory is accessed using the contents of general-purpose register RWj as an address. After operand operation, RWj is incremented by the operand size (1 for a byte, 2 for a word, or 4 for a long word). Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0 or RW1 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 is used, or additional data bank register (ADB) when RW2 is used.

If the post increment results in the address of the register that specifies the increment, the incremented value is referenced after that. In this case, if the next instruction is a write instruction, priority is given to writing by an instruction and, therefore, the register that would be incremented becomes write data.

Figure B.4-2 Example of Register Indirect Addressing with Post Increment (@RWj+ j = 0 to 3)



■ Register indirect addressing with offset (@RWi + disp8 i = 0 to 7, @RWj + disp16 j = 0 to 3)

Memory is accessed using the address obtained by adding an offset to the contents of general-purpose register RWj. Two types of offset, byte and word offsets, are used. They are added as signed numeric values. Address bits 16 to 23 are indicated by the data bank register (DTB) when RW0, RW1, RW4, or RW5 is used, system stack bank register (SSB) or user stack bank register (USB) when RW3 or RW7 is used, or additional data bank register (ADB) when RW2 or RW6 is used.

Figure B.4-3 Example of Register Indirect Addressing with Offset (@RWi + disp8 i = 0 to 7, @RWj + disp16 j = 0 to 3)



● Long register indirect addressing with offset (@RLi + disp8 i = 0 to 3)

Memory is accessed using the address that is the 24 low-order bits obtained by adding an offset to the contents of general-purpose register RLi. The offset is 8-bits long and is added as a signed numeric value.

Figure B.4-4 Example of Long Register Indirect Addressing with Offset (@RLi + disp8 i = 0 to 3)



#### Program counter indirect addressing with offset (@PC + disp16)

Memory is accessed using the address indicated by (instruction address + 4 + disp16). The offset is one word long. Address bits 16 to 23 are specified by the program bank register (PCB). Note that the operand address of each of the following instructions is not deemed to be (next instruction address + disp16):

- DBNZ eam, rel
- DWBNZ eam, rel
- CBNE eam, #imm8, rel
- CWBNE eam, #imm16, rel
- MOV eam, #imm8
- MOVW eam, #imm16

Figure B.4-5 Example of Program Counter Indirect Addressing with Offset (@PC + disp16)



Register indirect addressing with base index (@RW0 + RW7, @RW1 + RW7)

Memory is accessed using the address determined by adding RW0 or RW1 to the contents of general-purpose register RW7. Address bits 16 to 23 are indicated by the data bank register (DTB).

Figure B.4-6 Example of Register Indirect Addressing with Base Index (@RW0 + RW7, @RW1 + RW7)



#### Program counter relative branch addressing (rel)

The address of the branch destination is a value determined by adding an 8-bit offset to the program counter (PC) value. If the result of addition exceeds 16 bits, bank register incrementing or decrementing is not performed and the excess part is ignored, and therefore the address is contained within a 64-Kbyte bank. This addressing is used for both conditional and unconditional branch instructions. Address bits 16 to 23 are indicated by the program bank register (PCB).

Figure B.4-7 Example of Program Counter Relative Branch Addressing (rel)



#### Register list (rlst)

Specify a register to be pushed onto or popped from a stack.

Figure B.4-8 Configuration of the Register List





Figure B.4-9 Example of Register List (rlst)

#### Accumulator indirect addressing (@A)

Memory is accessed using the address indicated by the contents of the low-order bytes (16 bits) of the accumulator (AL). Address bits 16 to 23 are specified by a mnemonic in the data bank register (DTB).

MOVW A, @A (This instruction reads data by accumulator indirect addressing and stores it in A.)

Before execution A 0716:2534 Memory space

DTB BB

After execution A 0716:FFEE

DTB BB

Figure B.4-10 Example of Accumulator Indirect Addressing (@A)

#### Accumulator indirect branch addressing (@A)

The address of the branch destination is the content (16 bits) of the low-order bytes (AL) of the accumulator. It indicates the branch destination in the bank address space. Address bits 16 to 23 are specified by the program bank register (PCB). For the Jump Context (JCTX) instruction, however, address bits 16 to 23 are specified by the data bank register (DTB). This addressing is used for unconditional branch instructions.

Figure B.4-11 Example of Accumulator Indirect Branch Addressing (@A)



#### Indirect specification branch addressing (@ear)

The address of the branch destination is the word data at the address indicated by ear.

Figure B.4-12 Example of Indirect Specification Branch Addressing (@ear)



#### Indirect specification branch addressing (@eam)

The address of the branch destination is the word data at the address indicated by eam.

Figure B.4-13 Example of Indirect Specification Branch Addressing (@eam)



## **B.5** Execution Cycle Count

The number of cycles required for instruction execution (execution cycle count) is obtained by adding the number of cycles required for each instruction, "correction value" determined by the condition, and the number of cycles for instruction fetch.

#### **■** Execution Cycle Count

The number of cycles required for instruction execution (execution cycle count) is obtained by adding the number of cycles required for each instruction, "correction value" determined by the condition, and the number of cycles for instruction fetch. In the mode of fetching an instruction from memory such as internal ROM connected to a 16-bit bus, the program fetches the instruction being executed in word increments. Therefore, intervening in data access increases the execution cycle count.

Similarly, in the mode of fetching an instruction from memory connected to an 8-bit external bus, the program fetches every byte of an instruction being executed. Therefore, intervening in data access increases the execution cycle count. In CPU intermittent operation mode, access to a general-purpose register, internal ROM, internal RAM, internal I/O, or external data bus causes the clock to the CPU to halt for the cycle count specified by the CG0 and CG1 bits of the low power consumption mode control register. Therefore, for the cycle count required for instruction execution in CPU intermittent operation mode, add the "access count x cycle count for the halt" as a correction value to the normal execution count.

### ■ Calculating the execution cycle count

Table B.5-1 lists execution cycle counts and Table B.5-2 and Table B.5-3 summarize correction value data.

Table B.5-1 Execution Cycle Counts in Each Addressing Mode

| G 1                  |                                              | (a) *                                         | Register access count in each                 |  |
|----------------------|----------------------------------------------|-----------------------------------------------|-----------------------------------------------|--|
| Code                 | Operand                                      | Execution cycle count in each addressing mode | Register access count in each addressing mode |  |
| 00<br> <br>07        | Ri<br>Rwi<br>RLi                             | See the instruction list.                     | See the instruction list.                     |  |
| 08<br> <br>0B        | @RWj                                         | 2                                             | 1                                             |  |
| 0C<br> <br>0F        | @RWj+                                        | 4                                             | 2                                             |  |
| 10<br> <br>17        | @RWi+disp8                                   | 2                                             | 1                                             |  |
| 18<br> <br>1B        | @RWi+disp16                                  | 2                                             | 1                                             |  |
| 1C<br>1D<br>1E<br>1F | @RW0+RW7<br>@RW1+RW7<br>@PC+disp16<br>addr16 | 4<br>4<br>2<br>1                              | 2<br>2<br>0<br>0                              |  |

<sup>\*: (</sup>a) is used for  $\sim$  (cycle count) and B (correction value) in "B.8 F<sup>2</sup>MC-16LX Instruction List".

Table B.5-2 Cycle Count Correction Values for Counting Execution Cycles

|                                          | (b) byte *1 |              | (c) word *1 |              | (d) long *1 |              |
|------------------------------------------|-------------|--------------|-------------|--------------|-------------|--------------|
| Operand                                  | Cycle count | Access count | Cycle count | Access count | Cycle count | Access count |
| Internal register                        | +0          | 1            | +0          | 1            | +0          | 2            |
| Internal memory<br>Even address          | +0          | 1            | +0          | 1            | +0          | 2            |
| Internal memory<br>Odd address           | +0          | 1            | +2          | 2            | +4          | 4            |
| External data bus *2 16-bit even address | +1          | 1            | +1          | 1            | +2          | 2            |
| External data bus *2 16-bit odd address  | +1          | 1            | +4          | 2            | +8          | 4            |
| External data bus *2 8-bits              | +1          | 1            | +4          | 2            | +8          | 4            |

<sup>\*1: (</sup>b), (c), and (d) are used for ~ (cycle count) and B (correction value) in "B.8 F<sup>2</sup>MC-16LX Instruction List".

#### Note:

When an external data bus is used, the cycle counts during which an instruction is made to wait by ready input or automatic ready must also be added.

Table B.5-3 Cycle Count Correction Values for Counting Instruction Fetch Cycles

| Instruction               | Byte boundary | Word boundary |  |
|---------------------------|---------------|---------------|--|
| Internal memory           | -             | +2            |  |
| External data bus 16-bits | -             | +3            |  |
| External data bus 8-bits  | +3            | -             |  |

#### Note:

- When an external data bus is used, the cycle counts during which an instruction is made to wait by ready input or automatic ready must also be added.
- Actually, instruction execution is not delayed by every instruction fetch. Therefore, use the correction values to calculate the worst case.

<sup>\*2:</sup> When an external data bus is used, the number of cycles during which an instruction is made to wait by ready - signal input or automatic ready must also be added.

## **B.6** Effective address field

#### Table B.6-1 shows the effective address field.

#### **■** Effective Address Field

Table B.6-1 Effective Address Field

| Code | Representation           |     | ation   | Address format                                                            | Byte count of extended address part * |
|------|--------------------------|-----|---------|---------------------------------------------------------------------------|---------------------------------------|
| 00   | R0                       | RW0 | RL0     |                                                                           |                                       |
| 01   | R1                       | RW1 | (RL0)   |                                                                           |                                       |
| 02   | R2                       | RW2 | RL1     |                                                                           |                                       |
| 03   | R3                       | RW3 | (RL1)   | Register direct: Individual parts                                         |                                       |
| 04   | R4                       | RW4 | RL2     | correspond to the byte, word, and long word types in order from the left. | -                                     |
| 05   | R5                       | RW5 | (RL2)   | word types in order from the ferti                                        |                                       |
| 06   | R6                       | RW6 | RL3     |                                                                           |                                       |
| 07   | R7                       | RW7 | (RL3)   |                                                                           |                                       |
| 08   | @RW0                     |     |         |                                                                           |                                       |
| 09   | @RW1                     |     |         | Pagistar indirect                                                         | 0                                     |
| 0A   | @RW2                     |     |         | Register indirect                                                         |                                       |
| 0B   | @RW3                     |     |         |                                                                           |                                       |
| 0C   | @RW0+                    |     |         | Register indirect with post increment                                     | 0                                     |
| 0D   | @RW1+                    |     |         |                                                                           |                                       |
| 0E   | @RW2+                    |     |         |                                                                           |                                       |
| 0F   | @RW3+                    |     |         |                                                                           |                                       |
| 10   | @RW0+disp8               |     |         | Register indirect with 8-bit displacement                                 |                                       |
| 11   | @RW1+disp8               |     |         |                                                                           | 1                                     |
| 12   | @RW2+disp8               |     |         |                                                                           |                                       |
| 13   | @RW3+disp8               |     |         |                                                                           |                                       |
| 14   | @RW4+disp8               |     |         |                                                                           |                                       |
| 15   | @RW5+disp8               |     |         |                                                                           |                                       |
| 16   | @RW6+disp8<br>@RW7+disp8 |     |         |                                                                           |                                       |
| 17   |                          |     |         |                                                                           |                                       |
| 18   | @RW0+disp16              |     | <u></u> |                                                                           |                                       |
| 19   | @RW1+disp16              |     |         | Register indirect with 16-bit                                             | 2                                     |
| 1A   | @RW2+disp16              |     |         | displacement                                                              |                                       |
| 1B   | @RW3+disp16              |     |         |                                                                           |                                       |
| 1C   | @RW0+RW7                 |     |         | Register indirect with index                                              | 0                                     |
| 1D   | @RW1+RW7                 |     |         | Register indirect with index                                              | 0                                     |
| 1E   | @PC+disp16               |     |         | PC indirect with 16-bit displacement                                      | 2                                     |
| 1F   | addr16                   |     |         | Direct address                                                            | 2                                     |

<sup>\*:</sup> Each byte count of the extended address part applies to + in the # (byte count) column in "B.8  $F^2MC-16LX$  Instruction List". For the meaning of "#", see "B.7 How to Read the Instruction List".

# B.7 How to Read the Instruction List

Table B.7-1 describes the items used in the  $F^2MC$ -16LX Instruction List, and Table B.7-2 describes the symbols used in the same list.

# **■** Description of Instruction Presentation Items and Symbols

Table B.7-1 Description of Items in the Instruction List (1/2)

| Item      | Description                                                                                                                                                                                                                               |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Mnemonic  | Uppercase, symbol: Represented as is in the assembler. Lowercase: Rewritten in the assembler. Number of following lowercase: Indicates bit length in the instruction.                                                                     |
| #         | Indicates the number of bytes.                                                                                                                                                                                                            |
| ~         | Indicates the number of cycles.                                                                                                                                                                                                           |
| RG        | Indicates the number of times a register access is performed during instruction execution.  The number is used to calculate the correction value for CPU intermittent operation.                                                          |
| В         | Indicates the correction value used to calculate the actual number of cycles during instruction execution.  The actual number of cycles during instruction execution can be determined by adding the value in the ~ column to this value. |
| Operation | Indicates the instruction operation.                                                                                                                                                                                                      |
| LH        | Indicates the special operation for bits 15 to 08 of the accumulator.  Z: Transfers 0.  X: Transfers after sign extension.  -: No transfer                                                                                                |
| АН        | Indicates the special operation for the 16 high-order bits of the accumulator.  *: Transfers from AL to AH.  -: No transfer  Z: Transfers 00 to AH.  X: Transfers 00 <sub>H</sub> or FF <sub>H</sub> to AH after AL sign extension.       |
| I         |                                                                                                                                                                                                                                           |
| S         | Each indicates the state of each flag: I (interrupt enable), S (stack), T (sticky bit),                                                                                                                                                   |
| Т         | N (negative), Z (zero), V (overflow), C (carry).                                                                                                                                                                                          |
| N         | *: Changes upon instruction execution: No change                                                                                                                                                                                          |
| Z         | Z: Set upon instruction execution.                                                                                                                                                                                                        |
| V         | X: Reset upon instruction execution.                                                                                                                                                                                                      |
| С         |                                                                                                                                                                                                                                           |

Table B.7-1 Description of Items in the Instruction List (2/2)

| Item | Description                                                                                                                                                                                                                                                                                                                         |
|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RMW  | Indicates whether the instruction is a Read Modify Write instruction (reading data from memory by the I instruction and writing the result to memory).  *: Read Modify Write instruction  -: Not Read Modify Write instruction  Note:  Cannot be used for an address that has different meanings between read and write operations. |

Table B.7-2 Explanation on Symbols in the Instruction List (1/2)

| Symbol     | Explanation                                                                                                                                                               |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A          | The bit length used varies depending on the 32-bit accumulator instruction.  Byte: Low-order 8 bits of byte AL  Word: 16 bits of word AL  Long word: 32 bits of AL and AH |
| АН         | 16 high-order bits of A                                                                                                                                                   |
| AL         | 16 low-order bits of A                                                                                                                                                    |
| SP         | Stack pointer (USP or SSP)                                                                                                                                                |
| PC         | Program counter                                                                                                                                                           |
| PCB        | Program bank register                                                                                                                                                     |
| DTB        | Data bank register                                                                                                                                                        |
| ADB        | Additional data bank register                                                                                                                                             |
| SSB        | System stack bank register                                                                                                                                                |
| USB        | User stack bank register                                                                                                                                                  |
| SPB        | Current stack bank register (SSB or USB)                                                                                                                                  |
| DPR        | Direct page register                                                                                                                                                      |
| brg1       | DTB, ADB, SSB, USB, DPR, PCB, SPB                                                                                                                                         |
| brg2       | DTB, ADB, SSB, USB, DPR, SPB                                                                                                                                              |
| Ri         | R0, R1, R2, R3, R4, R5, R6, R7                                                                                                                                            |
| RWi        | RW0, RW1, RW2, RW3, RW4, RW5, RW6, RW7                                                                                                                                    |
| RWj        | RW0, RW1, RW2, RW3                                                                                                                                                        |
| RLi        | RL0, RL1, RL2, RL3                                                                                                                                                        |
| dir        | Abbreviated direct addressing                                                                                                                                             |
| addr16     | Direct addressing                                                                                                                                                         |
| addr24     | Physical direct addressing                                                                                                                                                |
| ad24 0-15  | Bits 0 to 15 of addr24                                                                                                                                                    |
| ad24 16-23 | Bits 16 to 23 of addr24                                                                                                                                                   |
| io         | I/O area (000000 <sub>H</sub> to 0000FF <sub>H</sub> )                                                                                                                    |

Table B.7-2 Explanation on Symbols in the Instruction List (2/2)

| Symbol     | Explanation                                                    |
|------------|----------------------------------------------------------------|
| #imm4      | 4-bit immediate data                                           |
| #imm8      | 8-bit immediate data                                           |
| #imm16     | 16-bit immediate data                                          |
| #imm32     | 32-bit immediate data                                          |
| ext (imm8) | 16-bit data obtained by sign extension of 8-bit immediate data |
| disp8      | 8-bit displacement                                             |
| disp16     | 16-bit displacement                                            |
| bp         | Bit offset                                                     |
| vct4       | Vector number (0 to 15)                                        |
| vct8       | Vector number (0 to 255)                                       |
| ( ) b      | Bit address                                                    |
| rel        | PC relative branch                                             |
| ear        | Effective addressing (code 00 to 07)                           |
| eam        | Effective addressing (code 08 to 1F)                           |
| rlst       | Register list                                                  |

# B.8 F<sup>2</sup>MC-16LX Instruction List

# Table B.8-1 to Table B.8-18 list the instructions used by the F<sup>2</sup>MC-16LX.

# ■ F<sup>2</sup>MC-16LX Instruction List

Table B.8-1 41 Transfer Instructions (byte)

| Mnemonic              | #  | ~       | RG | В       | Operation                          | L<br>H | A<br>H   | I | S        | Т   | N | Z | ٧ | С | R<br>M |
|-----------------------|----|---------|----|---------|------------------------------------|--------|----------|---|----------|-----|---|---|---|---|--------|
|                       |    |         |    |         |                                    |        |          |   |          |     |   |   |   |   | W      |
| MOV A,dir             | 2  | 3       | 0  | (b)     | byte (A) < (dir)                   | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,addr16          | 3  | 4       | 0  | (b)     | byte (A) < (addr16)                | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,Ri              | 1  | 2       | 1  | 0       | byte (A) < (Ri)                    | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,ear             | 2  | 2       | 1  | 0       | byte (A) < (ear)                   | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,eam             | 2+ | 3 + (a) | 0  | (b)     | byte (A) < (eam)                   | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,io              | 2  | 3       | 0  | (b)     | byte (A) < (io)                    | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,#imm8           | 2  | 2       | 0  | 0       | byte (A) < imm8                    | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOV A,@A              | 2  | 3       | 0  | (b)     | byte (A) < ((A))                   | Z      | -        | - | -        | *   | * | - | - | - | -      |
| MOV A,@RLi+disp8      | 3  | 10      | 2  | (b)     | byte (A) < ((RLi)+disp8)           | Z      | *        | - | -        | *   | * | - | - | - | -      |
| MOVN A,#imm4          | 1  | 1       | 0  | 0       | byte (A) < imm4                    | Z      | *        | - | -        | R   | * | - | - | - | -      |
| MOVX A,dir            | 2  | 3       | 0  | (b)     | byte (A) < (dir)                   | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,addr16         | 3  | 4       | 0  | (b)     | byte (A) < (addr16)                | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,Ri             | 2  | 2       | 1  | 0       | byte (A) < (Ri)                    | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,ear            | 2  | 2       | 1  | 0       | byte (A) < (ear)                   | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,eam            | 2+ | 3 + (a) | 0  | (b)     | byte (A) < (eam)                   | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,io             | 2  | 3       | 0  | (b)     | byte (A) < (io)                    | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,#imm8          | 2  | 2       | 0  | 0       | byte (A) < imm8                    | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOVX A,@A             | 2  | 3       | 0  | (b)     | byte (A) < ((A))                   | X      | -        | - | _        | -   | * | * | - | _ | _      |
| MOVX A,@RWi+disp8     | 2  | 5       | 1  | (b)     | byte (A) < ((RWi)+disp8)           | X      | *        | - | _        | -   | * | * | - | _ | -      |
| MOVX A,@RLi+disp8     | 3  | 10      | 2  | (b)     | byte (A) $\leftarrow$ ((RLi)+disp8 | X      | *        | - | -        | -   | * | * | - | - | -      |
| MOV dir,A             | 2  | 3       | 0  | (b)     | byte (dir) < (A)                   | -      | -        | - | -        | -   | * | * | - | - | -      |
| MOV addr16,A          | 3  | 4       | 0  | (b)     | byte (addr16) < (A)                | -      | -        | - | _        | -   | * | * | - | _ | _      |
| MOV Ri,A              | 1  | 2       | 1  | 0       | byte (Ri) < (A)                    | -      | -        | - | _        | -   | * | * | - | _ | _      |
| MOV ear,A             | 2  | 2       | 1  | 0       | byte (ear) < (A)                   | -      | -        | - | _        | -   | * | * | - | _ | -      |
| MOV eam,A             | 2+ | 3 + (a) | 0  | (b)     | byte (eam) < (A)                   | -      | -        | - | _        | -   | * | * | - | _ | -      |
| MOV io,A              | 2  | 3       | 0  | (b)     | byte (io) < (A)                    | -      | -        | - | _        | -   | * | * | - | _ | _      |
| MOV @RLi+disp8,A      | 3  | 10      | 2  | (b)     | byte ((RLi)+disp8) < (A)           | -      | -        | - | -        | -   | * | * | - | - | -      |
| MOV Ri,ear            | 2  | 3       | 2  | 0       | byte (Ri) < (ear)                  | -      | -        | - | -        | -   | * | * | - | _ | _      |
| MOV Ri,eam            | 2+ | 4 + (a) | 1  | (b)     | byte (Ri) < (eam)                  | -      | -        | - | _        | -   | * | * | - | _ | -      |
| MOV ear,Ri            | 2  | 4       | 2  | 0       | byte (ear) < (Ri)                  | -      | -        | - | -        | -   | * | * | - | _ | -      |
| MOV eam,Ri            | 2+ | 5 + (a) | 1  | (b)     | byte (eam) < (Ri)                  | _      | _        | _ | -        | -   | * | * | - | _ | _      |
| MOV Ri,#imm8          | 2  | 2       | 1  | 0       | byte (Ri) < imm8                   | _      | _        | _ | -        | -   | * | * | - | _ | _      |
| MOV io,#imm8          | 3  | 5       | 0  | (b)     | byte (io) < imm8                   | _      | l _      | _ | l _      | l - | _ | _ | _ | _ | _      |
| MOV dir.#imm8         | 3  | 5       | 0  | (b)     | byte (dir) < imm8                  | _      | _        | _ | _        | l _ | _ | _ | _ | _ | _      |
| MOV ear,#imm8         | 3  | 2       | 1  | 0       | byte (ear) < imm8                  | _      | _        | _ | _        | _   | * | * | _ | _ | _      |
| MOV eam,#imm8         | 3+ | 4 + (a) | 0  | (b)     | byte (eam) < imm8                  | _      | _        | _ | _        | _   | _ | _ | _ | _ | _      |
| MOV @AL,AH / MOV @A,T | 2  | 3       | 0  | (b)     | byte ((A)) < (AH)                  | _      | _        | _ | _        |     | * | * | _ | _ |        |
| XCH A,ear             | 2  | 4       | 2  | 0       | byte (A) <> (ear)                  | Z      | <u> </u> | _ | -        | -   | - | _ | _ | - | -      |
| XCH A,eam             | 2+ | 5 + (a) | 0  | 2 x (b) | byte (A) <> (eam)                  | Z      | _        | _ | _        |     | _ | _ | _ | _ |        |
| XCH Ri.ear            | 2  | 7       | 4  | 0       | byte (Ri) <> (earr)                | [_     | l _      | _ | _        | l . |   | _ | _ | _ |        |
| XCH Ri,eam            | 2+ | 9 + (a) | 2  | 2 x (b) | byte (Ri) <> (ear)                 |        | 1        | - |          |     |   |   |   |   |        |
| 71C11 14,00111        | -1 | > 1 (a) | -  | 2 A (U) | of a (ra) <> (can)                 |        |          |   | <u> </u> |     |   |   | _ | _ | لت     |

#### Note:

Table B.8-2 38 Transfer Instructions (byte)

| Mnemonic                | #  | ~       | RG | В       | Operation                | L<br>H | A<br>H | 1 | S | Т | N | Z | V | С | R<br>M<br>W |
|-------------------------|----|---------|----|---------|--------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVW A,dir              | 2  | 3       | 0  | (c)     | word (A) < (dir)         | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,addr16           | 3  | 4       | 0  | (c)     | word (A) < (addr16)      | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,SP               | 3  | 1       | 0  | 0       | word (A) < (SP)          | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,RWi              | 1  | 2       | 1  | 0       | word (A) < (RWi)         | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,ear              | 2  | 2       | 1  | 0       | word (A) < (ear)         | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,eam              | 2+ | 3 + (a) | 0  | (c)     | word (A) < (eam)         | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,io               | 2  | 3       | 0  | (c)     | word (A) < (io)          | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,@A               | 2  | 3       | 0  | (c)     | word (A) < ((A))         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW A,#imm16           | 3  | 2       | 2  | 0       | word (A) < imm16         | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,@RWi+disp8       | 2  | 5       | 1  | (c)     | word (A) < ((RWi)+disp8) | -      | *      | - | - | - | * | * | - | - | -           |
| MOVW A,@RLi+disp8       | 3  | 10      | 2  | (c)     | word (A) < ((RLi)+disp8) | -      | *      | - | - | - | * | * | - | - | - '         |
| MOVW dir,A              | 2  | 3       | 0  | (c)     | word (dir) < (A)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW addr16,A           | 3  | 4       | 0  | (c)     | word (addr16) < (A)      | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW SP,A               | 1  | 1       | 0  | 0       | word (SP) < (A)          | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW RWi,A              | 1  | 2       | 1  | 0       | word (RWi) < (A)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW ear,A              | 2  | 2       | 1  | 0       | word (ear) < (A)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,A              | 2+ | 3 + (a) | 0  | (c)     | word (eam) < (A)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW io,A               | 2  | 3       | 0  | (c)     | word (io) < (A)          | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW @RWi+disp8,A       | 2  | 5       | 1  | (c)     | word ((RWi)+disp8) < (A) | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW @RLi+disp8,A       | 3  | 10      | 2  | (c)     | word ((RLi)+disp8) < (A) | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW RWi,ear            | 2  | 3       | 2  | 0       | word (RWi) < (ear)       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW                    | 2+ | 4 + (a) | 1  | (c)     | word (RWi) < (eam)       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW ear,Rwi            | 2  | 4       | 2  | 0       | word (ear) < (RWi)       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,Rwi            | 2+ | 5 + (a) | 1  | (c)     | word (eam) < (RWi)       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW RWi,#imm16         | 3  | 2       | 1  | 0       | word (RWi) < imm16       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW io,#imm16          | 4  | 5       | 0  | (c)     | word (io) < imm16        | -      | -      | - | - | - | - | - | - | - | -           |
| MOVW ear,#imm16         | 4  | 2       | 1  | 0       | word (ear) < imm16       | -      | -      | - | - | - | * | * | - | - | -           |
| MOVW eam,#imm16         | 4+ | 4 + (a) | 0  | (c)     | word (eam) < imm16       | -      | -      | - | - | - | - | - | - | - | -           |
| MOVW @AL,AH / MOVW @A,T | 2  | 3       | 0  | (c)     | word ((A)) < (AH)        | -      | -      | - | - | - | * | * | - | - | -           |
| XCHW A,ear              | 2  | 4       | 2  | 0       | word (A) <> (ear)        | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW A,eam              | 2+ | 5 + (a) | 0  | 2 x (c) | word (A) <>(eam)         | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW RWi, ear           | 2  | 7       | 4  | 0       | word (RWi) <> (ear)      | -      | -      | - | - | - | - | - | - | - | -           |
| XCHW RWi, eam           | 2+ | 9 + (a) | 2  | 2 x (c) | word (RWi) <> (eam)      | -      | -      | - | - | - | - | - | - | - | - 1         |
| MOVL A,ear              | 2  | 4       | 2  | 0       | long (A) < (ear)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL A,eam              | 2+ | 5 + (a) | 0  | (d)     | long (A) < (eam)         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL A,#imm32           | 5  | 3       | 0  | 0       | long (A) < imm32         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL ear,A              | 2  | 4       | 2  | 0       | long (ear1) < (A)        | -      | -      | - | - | - | * | * | - | - | -           |
| MOVL eam,A              | 2+ | 5 + (a) | 0  | (d)     | long(eam1) < (A)         | -      | -      | - | - | - | * | * | - | - | -           |

Table B.8-3 42 Addition/subtraction Instructions (byte, word, long word)

|       | Mnemonic | #  | ~       | RG | В       | Operation                              | L<br>H   | A<br>H | I  | S | Т  | N | Z | V | С | R<br>M<br>W |
|-------|----------|----|---------|----|---------|----------------------------------------|----------|--------|----|---|----|---|---|---|---|-------------|
| ADD   | A,#imm8  | 2  | 2       | 0  | 0       | byte (A) < (A) + imm8                  | Z        | -      | -  | - | -  | * | * | * | * | -           |
| ADD   | A,dir    | 2  | 5       | 0  | (b)     | byte $(A) < (A) + (dir)$               | Z        | -      | -  | - | -  | * | * | * | * | _           |
| ADD   | A,ear    | 2  | 3       | 1  | 0       | byte $(A) < (A) + (ear)$               | Z        | -      | -  | - | -  | * | * | * | * | _           |
| ADD   | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) $<$ (A) + (eam)               | Z        | -      | -  | - | -  | * | * | * | * | _           |
| ADD   | ear,A    | 2  | 3       | 2  | 0       | byte (ear) < (ear) + (A)               | -        | -      | -  | - | -  | * | * | * | * | _           |
| ADD   | eam,A    | 2+ | 5 + (a) | 0  | 2 x (b) | byte (eam) < (eam) + (A)               | Z        | -      | -  | - | -  | * | * | * | * | *           |
| ADDC  | A        | 1  | 2       | 0  | 0       | byte $(A) < (AH) + (AL) + (C)$         | Z        | -      | -  | - | -  | * | * | * | * | _           |
| ADDC  | A,ear    | 2  | 3       | 1  | 0       | byte (A) $<$ (A) + (ear)+ (C)          | Z        | -      | -  | - | -  | * | * | * | * | _           |
| ADDC  | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte $(A) < (A) + (eam) + (C)$         | Z        | -      | -  | - | -  | * | * | * | * | -           |
| ADDDC | A        | 1  | 3       | 0  | 0       | byte (A) < (AH) + (AL) + (C) (decimal) | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUB   | A,#imm8  | 2  | 2       | 0  | 0       | byte (A) < (A) - imm8                  | Z        | -      | -  | - | -  | * | * | * | * | _           |
| SUB   | A,dir    | 2  | 5       | 0  | (b)     | byte (A) < (A) - (dir)                 | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUB   | A,ear    | 2  | 3       | 1  | 0       | byte (A) < (A) - (ear)                 | Z        | -      | -  | - | -  | * | * | * | * | _           |
| SUB   | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) - (eam)                 | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUB   | ear,A    | 2  | 3       | 2  | 0       | byte (ear) < (ear) - (A)               | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUB   | eam,A    | 2+ | 5 + (a) | 0  | 2 x (b) | byte (eam) < (eam) - (A)               | -        | -      | -  | - | -  | * | * | * | * | *           |
| SUBC  | A        | 1  | 2       | 0  | 0       | byte (A) < (AH) - (AL) - (C)           | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUBC  | A,ear    | 2  | 3       | 1  | 0       | byte (A) < (A) - (ear) - (C)           | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUBC  | A,eam    | 2+ | 4 + (a) | 0  | (b)     | byte (A) < (A) - (eam) - (C)           | Z        | -      | -  | - | -  | * | * | * | * | -           |
| SUBDC | A        | 1  | 3       | 0  | 0       | byte (A) < (AH) - (AL) - (C) (decimal) | Z        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | A        | 1  | 2       | 0  | 0       | word (A) < (AH) + (AL)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) + (ear)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) + (eam)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | A,#imm16 | 3  | 2       | 0  | 0       | word (A) < (A) + imm16                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | ear,A    | 2  | 3       | 2  | 0       | word (ear) < (ear) + (A)               | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDW  | eam,A    | 2+ | 5+(a)   | 0  | 2 x (c) | word (eam) < (eam) + (A)               | -        | -      | -  | - | -  | * | * | * | * | *           |
| ADDCW | A,ear    | 2  | 3       | 1  | 0       | word(A) <(A) + (ear) + (C)             | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDCW | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word(A) <(A) + (eam) + (C)             | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | A        | 1  | 2       | 0  | 0       | word (A) < (AH) - (AL)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) - (ear)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) - (eam)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | A,#imm16 | 3  | 2       | 0  | 0       | word (A) < (A) - imm16                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | ear,A    | 2  | 3       | 2  | 0       | word (ear) < (ear) - (A)               | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBW  | eam,A    | 2+ | 5+(a)   | 0  | 2 x (c) | word (eam) < (eam) - (A)               | -        | -      | -  | - | -  | * | * | * | * | *           |
| SUBCW | A,ear    | 2  | 3       | 1  | 0       | word (A) < (A) - (ear) - (C)           | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBCW | A,eam    | 2+ | 4+(a)   | 0  | (c)     | word (A) < (A) - (eam) - (C)           | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDL  | A,ear    | 2  | 6       | 2  | 0       | long (A) < (A) + (ear)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDL  | A,eam    | 2+ | 7+(a)   | 0  | (d)     | long (A) < (A) + (eam)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| ADDL  | A,#imm32 | 5  | 4       | 0  | 0       | long (A) < (A) + imm32                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBL  | A,ear    | 2  | 6       | 2  | 0       | long (A) < (A) - (ear)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBL  | A,eam    | 2+ | 7+(a)   | 0  | (d)     | long (A) < (A) - (eam)                 | -        | -      | -  | - | -  | * | * | * | * | -           |
| SUBL  | A,#imm32 | 5  | 4       | 0  | 0       | long (A) < (A) - imm32                 | <u> </u> | _      | L- | _ | L- | * | * | * | * | -           |

Table B.8-4 12 Increment/decrement Instructions (byte, word, long word)

|      | Mnemonic | #  | ~     | RG | В       | Operation              | LH | AH | I | S | Т | Z | Z | ٧ | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|------------------------|----|----|---|---|---|---|---|---|---|-------------|
| INC  | ear      | 2  | 3     | 2  | 0       | byte (ear) < (ear) + 1 | -  | -  | - | - | - | * | * | * | - | -           |
| INC  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) + 1 | -  | -  | - | - | - | * | * | * | - | *           |
| DEC  | ear      | 2  | 3     | 2  | 0       | byte (ear) < (ear) - 1 | -  | -  | - | - | - | * | * | * | - | -           |
| DEC  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) - 1 | -  | -  | - | - | - | * | * | * | - | *           |
| INCW | ear      | 2  | 3     | 2  | 0       | word (ear) < (ear) + 1 | -  | -  | - | - | - | * | * | * | - | -           |
| INCW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) + 1 | -  | -  | - | - | - | * | * | * | - | *           |
| DECW | ear      | 2  | 3     | 2  | 0       | word (ear) < (ear) - 1 | -  | -  | - | - | - | * | * | * | - | -           |
| DECW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) - 1 | -  | -  | - | - | - | * | * | * | - | *           |
| INCL | ear      | 2  | 7     | 4  | 0       | long (ear) < (ear) + 1 | -  | -  | - | - | - | * | * | * | - | -           |
| INCL | eam      | 2+ | 9+(a) | 0  | 2 x (d) | long (eam) < (eam) + 1 | -  | -  | - | - | - | * | * | * | - | *           |
| DECL | ear      | 2  | 7     | 4  | 0       | long (ear) < (ear) - 1 | -  | -  | - | - | - | * | * | * | - | -           |
| DECL | eam      | 2+ | 9+(a) | 0  | 2 x (d) | long (eam) < (eam) - 1 | -  | -  | - | - | - | * | * | * | - | *           |

See Table B.5-1 and Table B.5-2 for information on (a) to (d) in the table.

Table B.8-5 11 Compare Instructions (byte, word, long word)

|      | Mnemonic | #  | ~     | RG | В   | Operation        | L<br>H | A<br>H | 1 | S | Т | N | Z | ٧ | С | R<br>M<br>W |
|------|----------|----|-------|----|-----|------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| CMP  | A        | 1  | 1     | 0  | 0   | byte (AH) - (AL) | -      | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,ear    | 2  | 2     | 1  | 0   | byte (A) - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,eam    | 2+ | 3+(a) | 0  | (b) | byte (A) - (eam) | -      | -      | - | - | - | * | * | * | * | -           |
| CMP  | A,#imm8  | 2  | 2     | 0  | 0   | byte (A) - imm8  | -      | -      | - | - | - | * | * | * | * | -           |
| CMPW | A        | 1  | 1     | 0  | 0   | word (AH) - (AL) | -      | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,ear    | 2  | 2     | 1  | 0   | word (A) - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,eam    | 2+ | 3+(a) | 0  | (c) | word (A) - (eam) | -      | -      | - | - | - | * | * | * | * | -           |
| CMPW | A,#imm16 | 3  | 2     | 0  | 0   | word (A) - imm16 | -      | -      | - | - | - | * | * | * | * | -           |
| CMPL | A,ear    | 2  | 6     | 2  | 0   | long (A) - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| CMPL | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) - (eam) | -      | -      | - | - | - | * | * | * | * | -           |
| CMPL | A,#imm32 | 5  | 3     | 0  | 0   | long (A) - imm32 | -      | -      | - | - | - | * | * | * | * | -           |

# Note:

Table B.8-6 11 Unsigned Multiplication/division Instructions (word, long word)

| Mr    | nemonic | #  | ~   | RG | В   | Operation                                                         | L<br>H | A<br>H | 1 | S | Т | N | Z | V | С | R<br>M<br>W |
|-------|---------|----|-----|----|-----|-------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| DIVU  | A       | 1  | *1  | 0  | 0   | word (AH) / byte (AL)<br>quotient> byte (AL) remainder> byte (AH) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVU  | A,ear   | 2  | *2  | 1  | 0   | word (A) / byte (ear)<br>quotient> byte (A) remainder> byte (ear) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVU  | A,eam   | 2+ | *3  | 0  | *6  | word (A) / byte (eam)<br>quotient> byte (A) remainder> byte (eam) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVUW | A,ear   | 2  | *4  | 1  | 0   | long (A) / word (ear)<br>quotient> word (A) remainder> word (ear) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVUW | A,eam   | 2+ | *5  | 0  | *7  | long (A) / word (eam)<br>quotient> word (A) remainder> word (eam) | -      | -      | - | - | - | - | - | * | * | -           |
| MULU  | A       | 1  | *8  | 0  | 0   | byte (AH) * byte (AL)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULU  | A,ear   | 2  | *9  | 1  | 0   | byte (A) * byte (ear)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULU  | A,eam   | 2+ | *10 | 0  | (b) | byte (A) * byte (eam)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW | A       | 1  | *11 | 0  | 0   | word (AH) * word (AL)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW | A,ear   | 2  | *12 | 1  | 0   | word (A) * word (ear)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULUW | A,eam   | 2+ | *13 | 0  | (c) | word (A) * word (eam)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |

<sup>\*1: 3:</sup> Division by 0 7: Overflow 15: Normal

<sup>\*2: 4:</sup> Division by 0 8: Overflow 16: Normal

<sup>\*3: 6+(</sup>a): Division by 0 9+(a): Overflow 19+(a): Normal \*4: 4: Division by 0 7: Overflow 22: Normal

<sup>\*5: 6+(</sup>a): Division by 0 8+(a): Overflow 26+(a): Normal

<sup>\*6: (</sup>b): Division by 0 or overflow 2 x (b): Normal \*7: (c): Division by 0 or overflow 2 x (c): Normal

<sup>\*8: 3:</sup> Byte (AH) is 0. 7: Byte (AH) is not 0. \*9: 4: Byte (ear) is 0. 8: Byte (ear) is not 0. \*10: 5+(a): Byte (eam) is 0, 9+(a): Byte (eam) is not 0.

<sup>\*11: 3:</sup> Word (AH) is 0. 11: Word (AH) is not 0. \*12: 4: Word (ear) is 0. 12: Word (ear) is not 0.

<sup>\*13: 5+(</sup>a): Word (eam) is 0. 13+(a): Word (eam) is not 0.

Table B.8-7 11 Signed Multiplication/division Instructions (word, long word)

|      | Mnemonic | #  | ~   | RG | В   | Operation                                                         | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|----------|----|-----|----|-----|-------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| DIV  | A        | 2  | *1  | 0  | 0   | word (AH) / byte (AL)<br>quotient> byte (AL) remainder> byte (AH) | Z      | -      | - | - | - | - | - | * | * | -           |
| DIV  | A,ear    | 2  | *2  | 1  | 0   | word (A) / byte (ear)<br>quotient> byte (A) remainder> byte (ear) | z      | -      | - | - | - | - | - | * | * | -           |
| DIV  | A,eam    | 2+ | *3  | 0  | *6  | word (A) / byte (eam)<br>quotient> byte (A) remainder> byte (eam) | z      | -      | - | - | - | - | - | * | * | -           |
| DIVW | A,ear    | 2  | *4  | 1  | 0   | long (A) / word (ear)<br>quotient> word (A) remainder> word (ear) | -      | -      | - | - | - | - | - | * | * | -           |
| DIVW | A,eam    | 2+ | *5  | 0  | *7  | long (A) / word (eam)<br>quotient> word (A) remainder> word (eam) | -      | -      | - | - | - | - | - | * | * | -           |
| MUL  | A        | 2  | *8  | 0  | 0   | byte (AH) * byte (AL)> word (A)                                   | -      | -      | - | - | - | - | - | 1 | - | -           |
| MUL  | A,ear    | 2  | *9  | 1  | 0   | byte (A) * byte (ear)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MUL  | A,eam    | 2+ | *10 | 0  | (b) | byte (A) * byte (eam)> word (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | A        | 2  | *11 | 0  | 0   | word (AH) * word (AL)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | A,ear    | 2  | *12 | 1  | 0   | word (A) * word (ear)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |
| MULW | A,eam    | 2+ | *13 | 0  | (c) | word (A) * word (eam)> Long (A)                                   | -      | -      | - | - | - | - | - | - | - | -           |

<sup>\*1: 3:</sup> Division by 0, 8 or 18: Overflow, 18: Normal

- The execution cycle count found when an overflow occurs in a DIV or DIVW instruction may be a preoperation count or a post-operation count depending on the detection timing.
- When an overflow occurs with DIV or DIVW instruction, the contents of the AL are destroyed.
- See Table B.5-1 and Table B.5-2 for information on (a) to (d) in the table.

<sup>\*2: 4:</sup> Division by 0, 11 or 22: Overflow, 23: Normal

<sup>\*3: 5+(</sup>a): Division by 0, 12+(a) or 23+(a): Overflow, 24+(a): Normal

<sup>\*4:</sup> When dividend is positive; 4: Division by 0, 12 or 30: Overflow, 31: Normal

When dividend is negative; 4: Division by 0, 12 or 31: Overflow, 32: Normal

<sup>\*5:</sup> When dividend is positive; 5+(a): Division by 0, 12+(a) or 31+(a): Overflow, 32+(a): Normal

When dividend is negative; 5+(a): Division by 0, 12+(a) or 32+(a): Overflow, 33+(a): Normal

<sup>\*6: (</sup>b): Division by 0 or overflow, 2 x (b): Normal

\*7: (c): Division by 0 or overflow, 2 x (c): Normal

\*8: 3: Byte (AH) is 0, 12: result is positive, 13: result is negative

<sup>\*9: 4:</sup> Byte (ear) is 0, 13: result is positive, 14: result is negative \*10: 5+(a): Byte (ear) is 0, 14+(a): result is positive, 15+(a): result is negative

<sup>\*11: 3:</sup> Word (AH) is 0, 16: result is positive, 19: result is negative
\*12: 4: Word (ear) is 0, 16: result is positive, 20: result is negative
\*13: 5+(a): Word (eam) is 0, 18+(a): result is positive, 21+(a): result is negative

Table B.8-8 39 Logic 1 Instructions (byte, word)

| М    | Inemonic | #  | ~     | RG | В       | Operation                  | L | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|----------------------------|---|--------|---|---|---|---|---|---|---|-------------|
| AND  | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) and imm8    | - | -      | - | - | - | * | * | R | - | -           |
| AND  | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) and (ear)   | - | -      | - | - | - | * | * | R | - | -           |
| AND  | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) and (eam)   | - | -      | - | - | - | * | * | R | - | -           |
| AND  | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) and (A) | - | -      | - | - | - | * | * | R | - | -           |
| AND  | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) and (A) | - | -      | - | - | - | * | * | R | - | *           |
| OR   | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) or imm8     | - | -      | - | - | - | * | * | R | - | -           |
| OR   | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) or (ear)    | - | -      | - | - | - | * | * | R | - | -           |
| OR   | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) or (eam)    | - | -      | - | - | - | * | * | R | - | -           |
| OR   | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) or (A)  | - | -      | - | - | - | * | * | R | - | -           |
| OR   | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) or (A)  | - | -      | - | - | - | * | * | R | - | *           |
| XOR  | A,#imm8  | 2  | 2     | 0  | 0       | byte (A) < (A) xor imm8    | - | -      | - | - | - | * | * | R | - | -           |
| XOR  | A,ear    | 2  | 3     | 1  | 0       | byte (A) < (A) xor (ear)   | - | -      | - | - | - | * | * | R | - | -           |
| XOR  | A,eam    | 2+ | 4+(a) | 0  | (b)     | byte (A) < (A) xor (eam)   | - | -      | - | - | - | * | * | R | - | -           |
| XOR  | ear,A    | 2  | 3     | 2  | 0       | byte (ear) < (ear) xor (A) | - | -      | - | - | - | * | * | R | - | -           |
| XOR  | eam,A    | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < (eam) xor (A) | - | -      | - | - | - | * | * | R | - | *           |
| NOT  | A        | 1  | 2     | 0  | 0       | byte (A) < not (A)         | - | -      | - | - | - | * | * | R | - | -           |
| NOT  | ear      | 2  | 3     | 2  | 0       | byte (ear) < not (ear)     | - | -      | - | - | - | * | * | R | - | -           |
| NOT  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < not (eam)     | - | -      | - | - | - | * | * | R | - | *           |
| ANDW | A        | 1  | 2     | 0  | 0       | word (A) < (AH) and (A)    | - | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) and imm16   | - | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) and (ear)   | - | -      | - | - | - | * | * | R | - | -           |
| ANDW | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) and (eam)   | - | -      | - | - | - | * | * | R | - | -           |
| ANDW | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) and (A) | - | -      | - | - | - | * | * | R | - | -           |
| ANDW | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) and (A) | - | -      | - | - | - | * | * | R | - | *           |
| ORW  | A        | 1  | 2     | 0  | 0       | word (A) < (AH) or (A)     | - | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) or imm16    | - | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) or (ear)    | - | -      | - | - | - | * | * | R | - | -           |
| ORW  | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) or (eam)    | - | -      | - | - | - | * | * | R | - | -           |
| ORW  | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) or (A)  | - | -      | - | - | - | * | * | R | - | -           |
| ORW  | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) or (A)  | - | -      | - | - | - | * | * | R | - | *           |
| XORW | A        | 1  | 2     | 0  | 0       | word (A) < (AH) xor (A)    | - | -      | - | - | - | * | * | R | - | -           |
| XORW | A,#imm16 | 3  | 2     | 0  | 0       | word (A) < (A) xor imm16   | - | -      | - | - | - | * | * | R | - | -           |
| XORW | A,ear    | 2  | 3     | 1  | 0       | word (A) < (A) xor (ear)   | - | -      | - | - | - | * | * | R | - | -           |
| XORW | A,eam    | 2+ | 4+(a) | 0  | (c)     | word (A) < (A) xor (eam)   | - | -      | - | - | - | * | * | R | - | -           |
| XORW | ear,A    | 2  | 3     | 2  | 0       | word (ear) < (ear) xor (A) | - | -      | - | - | - | * | * | R | - | -           |
| XORW | eam,A    | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < (eam) xor (A) | - | -      | - | - | - | * | * | R | - | *           |
| NOTW | A        | 1  | 2     | 0  | 0       | word (A) < not (A)         | - | -      | - | - | - | * | * | R | - | -           |
| NOTW | ear      | 2  | 3     | 2  | 0       | word (ear) < not (ear)     | - | -      | - | - | - | * | * | R | - | -           |
| NOTW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < not (eam)     | _ | _      | _ | _ | _ | * | * | R | _ | *           |

Table B.8-9 6 Logic 2 Instructions (long word)

|      | Mnemonic | #  | ~     | RG | В   | Operation                | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|----------|----|-------|----|-----|--------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| ANDL | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) and (ear) | -      | -      | - | - | - | * | * | R | - | -           |
| ANDL | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) and (eam) | -      | -      | - | - | - | * | * | R | - | -           |
| ORL  | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) or (ear)  | -      | -      | - | - | - | * | * | R | - | -           |
| ORL  | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) or (eam)  | -      | -      | - | - | - | * | * | R | - | -           |
| XORL | A,ear    | 2  | 6     | 2  | 0   | long (A) < (A) xor (ear) | -      | -      | - | - | - | * | * | R | - | -           |
| XORL | A,eam    | 2+ | 7+(a) | 0  | (d) | long (A) < (A) xor (eam) | 1      | -      | - | - | - | * | * | R | - | -           |

See Table B.5-1 and Table B.5-2 for information on (a) to (d) in the table.

Table B.8-10 6 Sign Inversion Instructions (byte, word)

|      | Mnemonic | #  | ~     | RG | В       | Operation              | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| NEG  | A        | 1  | 2     | 0  | 0       | byte (A) < 0 - (A)     | X      | -      | - | - | - | * | * | * | * | -           |
| NEG  | ear      | 2  | 3     | 2  | 0       | byte (ear) < 0 - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| NEG  | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < 0 - (eam) | 1      | -      | - | - | - | * | * | * | * | *           |
| NEGW | A        | 1  | 2     | 0  | 0       | word (A) < 0 - (A)     | 1      | -      | - | - | - | * | * | * | * | -           |
| NEGW | ear      | 2  | 3     | 2  | 0       | word (ear) < 0 - (ear) | -      | -      | - | - | - | * | * | * | * | -           |
| NEGW | eam      | 2+ | 5+(a) | 0  | 2 x (c) | word (eam) < 0 - (eam) | -      | -      | - | - | - | * | * | * | * | *           |

# Note:

Table B.8-11 1 Normalization Instruction (long word)

|    | Mnemonic | # | ?  | RG | В | Operation                                                                                               | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|----|----------|---|----|----|---|---------------------------------------------------------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| NI | RML A,R0 | 2 | *1 | 1  | 0 | $\begin{array}{ll} long~(A) <\!\!-\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | 1      | 1      | - | - | - | - | * | - | - | -           |

<sup>\*1: 4</sup> when all accumulators have a value of 0; otherwise, 6+(R0)

Table B.8-12 18 Shift Instructions (byte, word, long word)

|      | Mnemonic | #  | ~     | RG | В       | Operation                                        | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|----------|----|-------|----|---------|--------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| RORC | A        | 2  | 2     | 0  | 0       | byte (A) < With right rotation carry             | -      | -      | - | - | - | * | * | - | * | -           |
| ROLC | A        | 2  | 2     | 0  | 0       | byte (A) < With left rotation carry              | -      | -      | - | - | - | * | * | - | * | -           |
| RORC | ear      | 2  | 3     | 2  | 0       | byte (ear) < With right rotation carry           | -      | -      | - | - | - | * | * | - | * | -           |
| RORC | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < With right rotation carry           | -      | -      | - | - | - | * | * | - | * | *           |
| ROLC | ear      | 2  | 3     | 2  | 0       | byte (ear) < With left rotation carry            | -      | -      | - | - | - | * | * | - | * | -           |
| ROLC | eam      | 2+ | 5+(a) | 0  | 2 x (b) | byte (eam) < With left rotation carry            | -      | -      | - | - | - | * | * | - | * | *           |
| ASR  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Arithmetic right shift (A, 1 bit)     | -      | -      | - | - | - | * | * | - | * | -           |
| LSR  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | - | * | * | - | * | -           |
| LSL  | A,R0     | 2  | *1    | 1  | 0       | byte (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |
| ASRW | A        | 1  | 2     | 0  | 0       | word (A) < Arithmetic right shift (A, 1 bit)     | -      | -      | - | - | * | * | * | - | * | -           |
| LSRW | A/SHRW A | 1  | 2     | 0  | 0       | word (A) < Logical right shift (A, 1 bit)        | -      | -      | - | - | * | R | * | - | * | -           |
| LSLW | A/SHLW A | 1  | 2     | 0  | 0       | word (A) < Logical left shift (A, 1 bit)         | -      | -      | - | - | - | * | * | - | * | -           |
| ASRW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Arithmetic right barrel shift (A, R0) | -      | -      | - | - | * | * | * | - | * | -           |
| LSRW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | * | * | * | - | * | -           |
| LSLW | A,R0     | 2  | *1    | 1  | 0       | word (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |
| ASRL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Arithmetic right barrel shift (A, R0) | -      | -      | - | - | * | * | * | - | * | -           |
| LSRL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Logical right barrel shift (A, R0)    | -      | -      | - | - | * | * | * | - | * | -           |
| LSLL | A,R0     | 2  | *2    | 1  | 0       | long (A) < Logical left barrel shift (A, R0)     | -      | -      | - | - | - | * | * | - | * | -           |

<sup>\*1: 6</sup> when R0 is 0; otherwise, 5 + (R0) \*2: 6 when R0 is 0; otherwise, 6 + (R0)

Table B.8-13 31 Branch 1 Instructions

| Mn      | emonic    | #  | ~      | RG | В       | Operation                                              | L<br>H | A<br>H | I | S | Т | N | Z | ٧ | С | R<br>M<br>W |
|---------|-----------|----|--------|----|---------|--------------------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| BZ/BEQ  | rel       | 2  | *1     | 0  | 0       | Branch on $(Z) = 1$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BNZ/BNE | rel       | 2  | *1     | 0  | 0       | Branch on $(Z) = 0$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BC/BLO  | rel       | 2  | *1     | 0  | 0       | Branch on $(C) = 1$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BNC/BHS | rel       | 2  | *1     | 0  | 0       | Branch on $(C) = 0$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BN      | rel       | 2  | *1     | 0  | 0       | Branch on $(N) = 1$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BP      | rel       | 2  | *1     | 0  | 0       | Branch on $(N) = 0$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BV      | rel       | 2  | *1     | 0  | 0       | Branch on $(V) = 1$                                    | -      | -      | - | - | - | - | - | - | - | - '         |
| BNV     | rel       | 2  | *1     | 0  | 0       | Branch on $(V) = 0$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BT      | rel       | 2  | *1     | 0  | 0       | Branch on $(T) = 1$                                    | -      | -      | - | - | - | - | - | - | - | - '         |
| BNT     | rel       | 2  | *1     | 0  | 0       | Branch on $(T) = 0$                                    | -      | -      | - | - | - | - | - | - | - | -           |
| BLT     | rel       | 2  | *1     | 0  | 0       | Branch on $(V)$ nor $(N) = 1$                          | -      | -      | - | - | - | - | - | - | - | -           |
| BGE     | rel       | 2  | *1     | 0  | 0       | Branch on $(V)$ nor $(N) = 0$                          | -      | -      | - | - | - | - | - | - | - | -           |
| BLE     | rel       | 2  | *1     | 0  | 0       | Branch on $((V) \text{ xor } (N)) \text{ or } (Z) = 1$ | -      | -      | - | - | - | - | - | - | - | -           |
| BGT     | rel       | 2  | *1     | 0  | 0       | Branch on $((V) \text{ xor } (N)) \text{ or } (Z) = 0$ | -      | -      | - | - | - | - | - | - | - | -           |
| BLS     | rel       | 2  | *1     | 0  | 0       | Branch on (C) or $(Z) = 1$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BHI     | rel       | 2  | *1     | 0  | 0       | Branch on (C) or $(Z) = 0$                             | -      | -      | - | - | - | - | - | - | - | -           |
| BRA     | rel       | 2  | *1     | 0  | 0       | Unconditional branch                                   | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @A        | 1  | 2      | 0  | 0       | word (PC) < (A)                                        | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | addr16    | 3  | 3      | 0  | 0       | word (PC) < addr16                                     | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @ear      | 2  | 3      | 1  | 0       | word (PC) < (ear)                                      | -      | -      | - | - | - | - | - | - | - | -           |
| JMP     | @eam      | 2+ | 4+(a)  | 0  | (c)     | word (PC) < (eam)                                      | -      | -      | - | - | - | - | - | - | - | -           |
| JMPP    | @ear *3   | 2  | 5      | 2  | 0       | word (PC) < (ear), (PCB) < (ear+2)                     | -      | -      | - | - | - | - | - | - | - | - '         |
| JMPP    | @eam *3   | 2+ | 6+(a)  | 0  | (d)     | word (PC) < (eam), (PCB) < (eam+2)                     | -      | -      | - | - | - | - | - | - | - | -           |
| JMPP    | addr24    | 4  | 4      | 0  | 0       | word (PC) < ad24 0-15, (PCB) < ad24 16-23              | -      | -      | - | - | - | - | - | - | - | - 1         |
| CALL    | @ear *4   | 2  | 6      | 1  | (c)     | word (PC) < (ear)                                      | -      | -      | - | - | - | - | - | - | - | -           |
| CALL    | addr16 *5 | 2+ | 7+(a)  | 0  | 2 x (c) | word (PC) < (eam)                                      | -      | -      | - | - | - | - | - | - | - | -           |
| CALL    | @eam *4   | 3  | 6      | 0  | (c)     | word (PC) < addr16                                     | -      | -      | - | - | - | - | - | - | - | -           |
| CALLV   | #vct4 *5  | 1  | 7      | 0  | 2 x (c) | Vector call instruction                                | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | @ear *6   | 2  | 10     | 2  | 2 x (c) | word (PC) < (ear)0-15, (PCB) < (ear)16-23              | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | @eam *6   | 2+ | 11+(a) | 0  | *2      | word (PC) < (eam)0-15, (PCB) < (eam)16-23              | -      | -      | - | - | - | - | - | - | - | -           |
| CALLP   | addr24 *7 | 4  | 10     | 0  | 2 x (c) | word (PC) < addr0-15, (PCB) < addr16-23                | -      | -      | - | - | - | - | - | - | - | -           |

<sup>\*1: 4</sup> when a branch is made; otherwise, 3 \*2: 3 x (c) + (b)

<sup>\*3:</sup> Read (word) of branch destination address
\*4: W: Save to stack (word) R: Read (word) of branch destination address

<sup>\*5:</sup> Save to stack (word)

<sup>\*6:</sup> W: Save to stack (long word), R: Read (long word) of branch destination address \*7: Save to stack (long word)

Table B.8-14 19 Branch 2 Instructions

|        | Mnemonic         | #  | ~  | RG | В       | Operation                                                                                                                                 | L | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|--------|------------------|----|----|----|---------|-------------------------------------------------------------------------------------------------------------------------------------------|---|--------|---|---|---|---|---|---|---|-------------|
| CBNE   | A,#imm8,rel      | 3  | *1 | 0  | 0       | Branch on byte (A) not equal to imm8                                                                                                      | - | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | A,#imm16,rel     | 4  | *1 | 0  | 0       | Branch on word (A) not equal to imm16                                                                                                     | - | -      | - | - | - | * | * | * | * | -           |
| CBNE   | ear,#imm8,rel    | 4  | *2 | 1  | 0       | Branch on byte (ear) not equal to imm8                                                                                                    | - | -      | - | - | - | * | * | * | * | -           |
| CBNE   | eam,#imm8,rel *9 | 4+ | *3 | 0  | (b)     | Branch on byte (eam) not equal to imm8                                                                                                    | - | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | ear,#imm16,rel   | 5  | *4 | 1  | 0       | Branch on word (ear) not equal to imm16                                                                                                   | - | -      | - | - | - | * | * | * | * | -           |
| CWBNE  | eam,#imm16,rel*9 | 5+ | *3 | 0  | (c)     | Branch on word (eam) not equal to imm16                                                                                                   | - | -      | - | - | - | * | * | * | * | -           |
| DBNZ   | ear,rel          | 3  | *5 | 2  | 0       | Branch on byte (ear) = (ear) - 1, (ear) not equal to 0                                                                                    | - | -      | - | - | - | * | * | * | - | -           |
| DBNZ   | eam,rel          | 3+ | *6 | 2  | 2 x (b) | Branch on byte (eam) = (eam) - 1, (eam) not equal to 0                                                                                    | - | -      | - | - | - | * | * | * | - | *           |
| DWBNZ  | ear,rel          | 3  | *5 | 2  | 0       | Branch on word (ear) = (ear) - 1, (ear) not equal to 0                                                                                    | - | -      | - | - | - | * | * | * | - | -           |
| DWBNZ  | eam,rel          | 3+ | *6 | 2  | 2 x (c) | Branch on word (eam) = $(eam) - 1$ , (eam) not equal to 0                                                                                 | - | -      | - | - | - | * | * | * | - | *           |
| INT    | #vct8            | 2  | 20 | 0  | 8 x (c) | Software interrupt                                                                                                                        | - | -      | R | S | - | - | - | - | - | -           |
| INT    | addr16           | 3  | 16 | 0  | 6 x (c) | Software interrupt                                                                                                                        | - | -      | R | S | - | - | - | - | - | -           |
| INTP   | addr24           | 4  | 17 | 0  | 6 x (c) | Software interrupt                                                                                                                        | - | -      | R | S | - | - | - | - | - | -           |
| INT9   |                  | 1  | 20 | 0  | 8 x (c) | Software interrupt                                                                                                                        | - | -      | R | S | - | - | - | - | - | -           |
| RETI   |                  | 1  | *8 | 0  | *7      | Return from interrupt                                                                                                                     | - | -      | * | * | * | * | * | * | * | -           |
| LINK   | #imm8            | 2  | 6  | 0  | (c)     | Saves the old frame pointer in the stack upon entering the function, then sets the new frame pointer and reserves the local pointer area. | - | -      | - | - | - | - | - | - | 1 | -           |
| UNLINK |                  | 1  | 5  | 0  | (c)     | Recovers the old frame pointer from the stack upon exiting the function.                                                                  | - | -      | - | - | - | - | - | - | - | -           |
| RET    | *10              | 1  | 4  | 0  | (c)     | Return from subroutine                                                                                                                    | - | -      | - | - | - | - | - | - | - | -           |
| RETP   | *11              | 1  | 6  | 0  | (d)     | Return from subroutine                                                                                                                    | - | -      | - | - | - | - | - | - | - | -           |

<sup>\*1: 5</sup> when a branch is made; otherwise, 4

<sup>\*2: 13</sup> when a branch is made; otherwise, 12

<sup>\*3: 7+(</sup>a) when a branch is made; otherwise, 6+(a)

<sup>\*4: 8</sup> when a branch is made; otherwise, 7

<sup>\*5: 7</sup> when a branch is made; otherwise, 6

<sup>\*6: 8+(</sup>a) when a branch is made; otherwise, 7+(a)

<sup>\*7: 3</sup> x (b) + 2 x (c) when jumping to the next interruption request; 6 x (c) when returning from the current interruption

<sup>\*8: 15</sup> when jumping to the next interruption request; 17 when returning from the current interruption
\*9: Do not use RWj+ addressing mode with a CBNE or CWBNE instruction.

<sup>\*10:</sup> Return from stack (word)

<sup>\*11:</sup> Return from stack (long word)

Table B.8-15 28 Other Control Instructions (byte, word, long word)

| Mn    | nemonic   | #  | ~          | RG | В       | Operation                                                                  | L | A<br>H | I | S  | Т | N | Z | ٧ | С | R<br>M<br>W |
|-------|-----------|----|------------|----|---------|----------------------------------------------------------------------------|---|--------|---|----|---|---|---|---|---|-------------|
| PUSHW | A         | 1  | 4          | 0  | (c)     | word (SP) < (SP) - 2, ((SP)) < (A)                                         | _ | _      |   |    | - | _ | _ | _ |   | H           |
| PUSHW | AH        | 1  | 4          | 0  | (c)     | word (SP) < (SP) - 2, ((SP)) < (AH)                                        |   |        | _ | -  |   |   |   |   | _ | _           |
| PUSHW | PS        | 1  | 4          | 0  | (c)     | word (SP) < (SP) - 2, ((SP)) < (PS)                                        |   | -      | _ | _  |   | _ |   |   | _ | _           |
| PUSHW | rlst      | 2  | *3         | *5 | *4      | (SP) < (SP) - 2n, ((SP)) < (rlst)                                          |   |        | _ | _  |   | _ |   |   |   | _           |
| POPW  | A         | 1  | 3          | 0  | (c)     | word (A) < ((SP)), (SP) < (SP) + 2                                         | - | *      | _ | -  | - | - | - | - | _ |             |
| POPW  | AH        | 1  | 3          | 0  | (c)     | word (AH) < ((SP)), (SP) < (SP) + 2                                        |   |        | _ | _  |   | _ |   |   | _ | _           |
| POPW  | PS        | 1  | 4          | 0  | (c)     | word (PS) < ((SP)), (SP) < (SP) + 2<br>word (PS) < ((SP)), (SP) < (SP) + 2 | _ |        | * | *  | * | * | * | * | * | _           |
| POPW  | rlst      | 2  | *2         | *5 | *4      | (rlst) < ((SP)), (SP) < (SP)                                               | - | -      |   |    |   |   |   |   |   | _           |
| JCTX  | @A        | 1  | 14         | 0  | 6 x (c) | Context switch instruction                                                 | - | Ε-     | * | *  | * | * | * | * | * | _           |
| AND   | CCR.#imm8 | 2  | 3          | 0  | 0 x (c) | byte (CCR) < (CCR) and imm8                                                | - | -      | * | *  | * | * | * | * | * | -           |
| OR    | CCR,#imm8 | 2  | 3          | 0  | 0       | byte (CCR) < (CCR) or imm8                                                 | _ | -      | * | *  | * | * | * | * | * | _           |
| MOV   | RP.#imm8  | 2  | 2          | 0  | 0       | byte (CCR) < (CCR) or inim8                                                | - | -      |   | -  |   | - | _ |   |   | -           |
| MOV   | ILM.#imm8 | 2  | 2          | 0  | 0       | byte (ILM) < imm8                                                          | _ | _      | - | _  |   | _ | _ |   | _ | _           |
| MOVEA | RWi,ear   | 2  | 3          | 1  | 0       | word (RWi) < ear                                                           |   | -      | - | Ε. |   | _ | - | - | _ | -           |
| MOVEA | RWi,ean   | 2+ | 3<br>2+(a) | 1  | 0       | word (RWi) < ear<br>word (RWi) < eam                                       | _ | _      | - | -  | - | _ | _ |   | _ | _           |
| MOVEA |           |    | 2+(a)<br>1 | 0  | 0       | word (Rwi) < eari                                                          | - | *      | - | -  | - |   |   |   |   | -           |
|       | A,ear     | 2  | _          | 0  | -       | ` '                                                                        | - | *      | - | -  | - | - | - | - | - | -           |
| MOVEA | A,eam     | 2+ | 1+(a)      | -  | 0       | word (A) < eam                                                             | - | *      | - | -  | - | - | - | - | - | -           |
| ADDSP | #imm8     | 2  | 3          | 0  | 0       | word (SP) < ext(imm8)                                                      | - | -      | - | -  | - | - | - | - | - | -           |
| ADDSP | #imm16    | 3  | 3 *1       | 0  | 0       | word (SP) < imm16                                                          | - | *      | - | -  | - | * | * | - | - | -           |
| MOV   | A,brg1    | 2  | _          | 0  | 0       | byte (A) < (brg1)                                                          | Z |        | - | -  | - | * | * | - | - | -           |
| MOV   | brg2,A    | 2  | 1          | 0  | 0       | byte (brg2) < (A)                                                          | - | -      | - | -  | - |   |   | - | - | -           |
| NOP   |           | 1  | 1          | 0  | 0       | No operation                                                               | - | -      | - | -  | - | - | - | - | - | -           |
| ADB   |           | 1  | 1          | 0  | 0       | Prefix code for AD space access                                            | - | -      | - | -  | - | - | - | - | - | -           |
| DTB   |           | 1  | 1          | 0  | 0       | Prefix code for DT space access                                            | - | -      | - | -  | - | - | - | - | - | -           |
| PCB   |           |    | 1          | 0  | 0       | Prefix code for PC space access                                            | - | -      | - | -  | - | - | - | - | - | -           |
| SPB   |           | 1  | 1          | 0  | 0       | Prefix code for SP space access                                            | - | -      | - | -  | - | - | - | - | - | -           |
| NCC   |           | 1  | 1          | 0  | 0       | Prefix code for flag no-change                                             | - | -      | - | -  | - | - | - | - | - | -           |
| CMR   |           | 1  | 1          | 0  | 0       | Prefix code for common register bank                                       | - | -      | - | -  | - | - | - | - | - | -           |

<sup>\*1:</sup> PCB, ADB, SSB, USB, SPB: 1, DTB, DPR: 2

<sup>\*2: 7+3</sup> x (POP count) +2 x (POP last register number), 7 when RLST = 0 (no transfer register)
\*3: 29 + 3 x (PUSH count) - 3 x (PUSH last register number), 8 when RLST = 0 (no transfer register)

<sup>\*4: (</sup>POP count) x (c) or (PUSH count) x (c)
\*5: (POP count) or (PUSH count)

Table B.8-16 21 Bit Operand Instructions

| M    | Inemonic      | # | ~  | RG | В       | Operation                               | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|------|---------------|---|----|----|---------|-----------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVB | A,dir:bp      | 3 | 5  | 0  | (b)     | byte (A) < (dir:bp)b                    | Z      | *      | - | - | - | * | * | - | - | -           |
| MOVB | A,addr16:bp   | 4 | 5  | 0  | (b)     | byte (A) < (addr16:bp)b                 | Z      | *      | - | - | - | * | * | - | - | -           |
| MOVB | A,io:bp       | 3 | 4  | 0  | (b)     | byte (A) < (io:bp)b                     | Z      | *      | - | - | - | * | * | - | - | -           |
| MOVB | dir:bp,A      | 3 | 7  | 0  | 2 x (b) | bit (dir:bp)b < (A)                     | -      | -      | - | - | - | * | * | - | - | *           |
| MOVB | addr16:bp,A   | 4 | 7  | 0  | 2 x (b) | bit (addr16:bp)b < (A)                  | -      | -      | - | - | - | * | * | - | - | *           |
| MOVB | io:bp,A       | 3 | 6  | 0  | 2 x (b) | bit (io:bp)b < (A)                      | -      | -      | - | - | - | * | * | - | - | *           |
| SETB | dir:bp        | 3 | 7  | 0  | 2 x (b) | bit (dir:bp)b < 1                       | -      | -      | - | - | - | - | - | - | - | *           |
| SETB | addr16:bp     | 4 | 7  | 0  | 2 x (b) | bit (addr16:bp)b < 1                    | -      | -      | - | - | - | - | - | - | - | *           |
| SETB | io:bp         | 3 | 7  | 0  | 2 x (b) | bit (io:bp)b < 1                        | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | dir:bp        | 3 | 7  | 0  | 2 x (b) | bit (dir:bp)b < 0                       | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | addr16:bp     | 4 | 7  | 0  | 2 x (b) | bit (addr16:bp)b < 0                    | -      | -      | - | - | - | - | - | - | - | *           |
| CLRB | io:bp         | 3 | 7  | 0  | 2 x (b) | bit (io:bp)b < 0                        | -      | -      | - | - | - | - | - | - | - | *           |
| BBC  | dir:bp,rel    | 4 | *1 | 0  | (b)     | Branch on (dir:bp) $b = 0$              | -      | -      | - | - | - | - | * | - | - | -           |
| BBC  | addr16:bp,rel | 5 | *1 | 0  | (b)     | Branch on (addr16:bp) $b = 0$           | -      | -      | - | - | - | - | * | - | - | -           |
| BBC  | io:bp,rel     | 4 | *2 | 0  | (b)     | Branch on (io:bp) $b = 0$               | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | dir:bp,rel    | 4 | *1 | 0  | (b)     | Branch on (dir:bp) b = 1                | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | addr16:bp,rel | 5 | *1 | 0  | (b)     | Branch on (addr16:bp) b = 1             | -      | -      | - | - | - | - | * | - | - | -           |
| BBS  | io:bp,rel     | 4 | *1 | 0  | (b)     | Branch on (io:bp) b = 1                 | -      | -      | - | - | - | - | * | - | - | -           |
| SBBS | addr16:bp,rel | 5 | *3 | 0  | 2 x (b) | Branch on (addr16:bp) $b = 1$ , bit = 1 | -      | -      | - | - | - | - | * | - | - | *           |
| WBTS | io:bp         | 3 | *4 | 0  | *5      | Waits until (io:bp) b = 1               | -      | -      | - | - | - | - | - | - | - | - '         |
| WBTC | io:bp         | 3 | *4 | 0  | *5      | Waits until (io:bp) b = 0               | -      | -      | - | - | - | - | - | - | - | -           |

<sup>\*1: 8</sup> when a branch is made; otherwise, 7

Table B.8-17 6 Accumulator Operation Instructions (byte, word)

| Mnemonic | # | ~ | RG | В | Operation              | L<br>H | A<br>H | I | S | Т | N | Z | V | С | R<br>M<br>W |
|----------|---|---|----|---|------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| SWAP     | 1 | 3 | 0  | 0 | byte (A)0-7 <> (A)8-15 | -      | -      | - | - | - | - | - | - | - | -           |
| SWAPW    | 1 | 2 | 0  | 0 | word (AH) <> (AL)      | -      | *      | - | - | - | - | - | - | - | -           |
| EXT      | 1 | 1 | 0  | 0 | Byte sign extension    | X      | -      | - | - | - | * | * | - | - | -           |
| EXTW     | 1 | 2 | 0  | 0 | Word sign extension    | -      | X      | - | - | - | * | * | - | - | -           |
| ZEXT     | 1 | 1 | 0  | 0 | Byte zero extension    | Z      | -      | - | - | - | R | * | - | - | -           |
| ZEXTW    | 1 | 1 | 0  | 0 | Word zero extension    | -      | z      | - | - | - | R | * | - | - | -           |

<sup>\*2: 7</sup> when a branch is made; otherwise, 6
\*3: 10 when the condition is met; otherwise, 9

<sup>\*4:</sup> Undefined count

<sup>\*5:</sup> Until the condition is met

Table B.8-18 10 String Instructions

| Mnemonic       | # | ~    | RG | В  | Operation                                | L<br>H | A<br>H | ı | S | Т | N | Z | V | С | R<br>M<br>W |
|----------------|---|------|----|----|------------------------------------------|--------|--------|---|---|---|---|---|---|---|-------------|
| MOVS / MOVSI   | 2 | *2   | *5 | *3 | byte transfer @AH+ < @AL+, counter = RW0 | -      | -      | - | - | - | - | - | - | - | _           |
| MOVSD          | 2 | *2   | *5 | *3 | byte transfer @AH- < @AL-, counter = RW0 | -      | -      | - | - | - | - | - | - | - | -           |
| SCEQ / SCEQI   | 2 | *1   | *5 | *4 | byte search @AH+ < AL, counter RW0       | -      | -      | - | - | - | * | * | * | * | -           |
| SCEQD          | 2 | *1   | *5 | *4 | byte search @AH- < AL, counter RW0       | -      | -      | - | - | - | * | * | * | * | -           |
| FILS / FILSI   | 2 | 6m+6 | *5 | *3 | byte fill @AH+ < AL, counter RW0         | -      | -      | - | - | - | * | * | - | - | -           |
| MOVSW / MOVSWI | 2 | *2   | *5 | *6 | word transfer @AH+ < @AL+, counter = RW0 | -      | -      | - | - | - | - | - | - | - | -           |
| MOVSWD         | 2 | *2   | *5 | *6 | word transfer @AH- < @AL-, counter = RW0 | -      | -      | - | - | - | - | - | - | - | -           |
| SCWEQ / SCWEQI | 2 | *1   | *5 | *7 | word search @AH+ - AL, counter = RW0     | -      | -      | - | - | - | * | * | * | * | -           |
| SCWEQD         | 2 | *1   | *5 | *7 | word search @AH AL, counter = RW0        | -      | -      | - | - | - | * | * | * | * | -           |
| FILSW / FILSWI | 2 | 6m+6 | *5 | *6 | word fill @AH+ < AL, counter = RW0       | 1      | 1      | 1 | 1 | - | * | * | 1 | - | -           |

<sup>\*1: 5</sup> when RW0 is  $0, 4 + 7 \times (RW0)$  when the counter expires, or 7n + 5 when a match occurs

m: RW0 value (counter value), n: Loop count

<sup>\*2: 5</sup> when RW0 is 0; otherwise,  $4 + 8 \times (RW0)$ 

<sup>\*3: (</sup>b) x (RW0) + (b) x (RW0) When the source and destination access different areas, calculate the (b) item individually.

<sup>\*4: (</sup>b) x n

<sup>\*5: 2</sup> x (RW0)

<sup>\*6: (</sup>c) x (RW0) + (c) x (RW0) When the source and destination access different areas, calculate the (c) item individually.

<sup>\*7: (</sup>c) x n

# **B.9** Instruction Map

Each  $F^2MC$ -16LX instruction code consists of 1 or 2 bytes. Therefore, the instruction map consists of multiple pages. Table B.9-2 to Table B.9-21 summarize the  $F^2MC$ -16LX instruction map.

# **■** Structure of Instruction Map

Bit operation instructions

Character string operation instructions

2-byte instructions

ea instructions x 9

Byte 1

Eyte 2

Figure B.9-1 Structure of Instruction Map

An instruction such as the NOP instruction that ends in one byte is completed within the basic page. An instruction such as the MOVS instruction that requires two bytes recognizes the existence of byte 2 when it references byte 1, and can check the following one byte by referencing the map for byte 2. Figure B.9-2 shows the correspondence between an actual instruction code and instruction map.



Figure B.9-2 Correspondence between Actual Instruction Code and Instruction Map

Table B.9-1 Example of an Instruction Code

An example of an instruction code is shown in Table B.9-1.

| Instruction    | Byte 1<br>(from basic page map) | Byte 2 (from extended page map) |
|----------------|---------------------------------|---------------------------------|
| NOP            | 00 +0=00                        | -                               |
| AND A, #8      | 30 +4=34                        | -                               |
| MOV A, ADB     | 60 +F=6F                        | 00 +0=00                        |
| @RW2+d8, #8rel | 70 +0=70                        | F0 +2=F2                        |

Table B.9-2 Basic Page Map

| 02 | ΔÄ          | re      | BNE                   | <u> </u> | <u> </u> | BHS         | re       |             | re     |             | re     |             | re             |             | re       |             | <u>e</u> |        | re     |          | re       |      | <u>le</u> |               | <u>e</u>    |       | <u>a</u> |                            | re               |          | <u>a</u> |
|----|-------------|---------|-----------------------|----------|----------|-------------|----------|-------------|--------|-------------|--------|-------------|----------------|-------------|----------|-------------|----------|--------|--------|----------|----------|------|-----------|---------------|-------------|-------|----------|----------------------------|------------------|----------|----------|
|    | BZ /BEQ     | Ţ.      | BNZ/BNE               |          | )        | BNC /BHS    |          | BN          | _      | ВР          |        | BV          |                | BNV         |          | В           |          | BNT    |        | BLT      |          | BGE  |           | BLE           |             | BGT   |          | BLS                        |                  | H        |          |
| EO | CALLV       | #4      | _                     | -        |          |             |          |             |        |             |        |             |                |             |          |             |          |        |        |          |          |      |           |               |             |       |          |                            |                  | <b>-</b> | •        |
| D0 | MOVN        | A,#4    | _                     |          |          |             |          |             |        |             |        |             |                |             |          |             |          |        |        |          |          |      |           |               |             |       |          |                            |                  | <b>→</b> | •        |
| 8  | MOVX A,     | @RWi+d8 | _                     |          |          |             |          |             |        |             |        |             |                | <u></u>     | -        | MOVW @R     | Wi+d8,A  |        |        |          |          |      |           |               |             |       |          |                            |                  | <b></b>  | •        |
| BO | MOV         | A,Ri    |                       |          |          |             |          |             |        |             |        |             |                |             | •        | MOVW A,     | @RWi+d8  |        |        |          |          |      |           |               |             |       |          |                            |                  | <b>→</b> | •        |
| A0 | MOV         | Ri,#8   |                       |          |          |             |          |             |        |             |        |             |                |             | -        | MOVW        | RWi,#16  |        |        |          |          |      |           |               |             |       |          |                            |                  | <b>-</b> | •        |
| 06 | MOV         | Ri,A    |                       |          |          |             |          |             |        |             |        |             |                |             | -        | MOVW        | RWi,A    |        |        |          |          |      |           |               |             |       |          |                            |                  |          |          |
| 80 | MOV         | A,Ri    | _                     |          |          |             |          |             |        |             |        |             |                |             | •        | MOVW        | A,RWi    |        |        |          |          |      |           |               |             |       |          |                            |                  | <b>-</b> | •        |
| 70 | ea instruc- | I HOIT  | ea instruc-<br>tion 2 | -        | tion 3   | ea instruc- | tion 4   | ea instruc- |        | ea instruc- | tion 6 | ea instruc- | tion 7         | ea instruc- | tion 8   | ea instruc- | tion 9   | MOVEA  | RWi,ea | MOV      | Ri,ea    | MOVW | RWi,ea    | MOV           | ea,Ri       | MOVW  | ea,RWi   | XCH                        |                  | χ̈́      | RWi,ea   |
| 09 | BRA         | re      | JMP @A                | IMP      | addr16   | JMPP        | addr24   | CAL         | addr16 | CALLP       | addr24 | RETP        |                | RET         |          | INT         | #vct8    | INT    | addr16 | INTP     | addr24   | RETI |           | Bit operation | instruction |       |          | Character<br>string opera- | tion instruction | 2-byte   |          |
| 90 | MOV         | A,io    | MOV                   | MOV      | A.addr16 | MOV         | addr16,A | MOV         | 9#'oi  | MOVX        | A,io   | MOVW        | io,#16         | MOVX        | A,addr16 | MOVW        | A,io     | MOVW   | A,oi   | MOVW     | A,addr16 | MOVW | addr16,A  | POPW          | ¥           | POPW  | AH       | POPW                       | PS               | POPW     | rlst     |
| 40 | MOV         | A,dir   | MOV                   | NOW.     | A,#8     | MOVX        | A,#8     | MOV         | dir,#8 | MOVX        | A,dir  | MOVW        | A,SP           | MOVW        | SP,A     | MOVW        | A,dir    | MOVW   | dir,A  | MOVW     | A,#16    | MOVL | A,#32     | PUSHW         | A           | PUSHW | AH       | PUSHW                      | - 1              | PUSHW    | rlst     |
| 30 | ADD         | A,#8    | SUB<br>A.#8           | OH IS    |          | CMP         | A,#8     | AND         | A,#8   | OR          | A,#8   | XOR         | A,#8           | NOT         | A        | ADDW        | A,#16    | SUBW   | A,#16  | CWBNE A, | #16,rel  | CMPW | A,#16     | ANDW          |             | ORW   | A,#16    | XORW                       | A,#16            | WLON     | A        |
| 50 | ADD         | A,dir   | SUB<br>A.dir          | ADDC     |          | CMP         | A        | AND         | CCR,#8 | OR          | CCR,#8 | DIVU        | А              | MULU        | A        | ADDW        | A        | SUBW   | A      | CBNE A,  | #8,rel   | CMPW | <b>∀</b>  | ANDW          | A           | ORW   | ∢        | XORW                       | ⋖                | MULUW    | A        |
| 10 | CMR         |         | NCC                   | SIBDC    |          | JCTX        | @ A      | EXT         |        | ZEXT        |        | SWAP        |                | ADDSP       | 8#       | ADDL        | A,#32    | SUBL   | A,#32  | MOV      | ILM,#8   | CMPL | A,#32     | EXTW          |             | ZEXTW |          | SWAPW                      |                  | ADDSP    | #16      |
| 00 | NOP         |         | 6LNI                  | ADDDC    | ₹        | NEG         | ∢        | PCB         |        | DTB         |        | ADB         |                | SPB         |          | LINK        | #imm8    | UNLINK |        | MOV      | RP,#8    | NEGW |           | RSLW          | ⋖           |       |          | ASRW                       | A                | LSRW     | ∢        |
|    | 0+          | 2       | +                     |          | + 2      |             | ب<br>+   | 7 +         | -      |             | c<br>+ | -           | 9 <del>+</del> |             | / +      |             | 8<br>+   |        | 6+     |          | +<br>+   |      | м<br>+    |               | ပ<br>+      |       | Ω<br>+   | ı                          | +<br>+           | <u>ц</u> | L<br> -  |

Table B.9-3 Bit Operation Instruction Map (first byte =  $6C_H$ )



Table B.9-4 Character String Operation Instruction Map (first byte =  $6E_H$ )

| F0 |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
|----|-----------------------------------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|-------------|
| EO | FILSWI<br>PCB                     | DTB     | ADB     | ▼ SPB   |         |         |         |         |         |         |         |         |         |         |         |             |
| 8  |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 8  | FILSI<br>PCB                      |         |         | ▼ SPB   |         |         |         |         |         |         |         |         |         |         |         |             |
| BO | SCEQI SCEQD SCWEQI SCWEQD PCB PCB | DTB     | ADB     | ▼ SPB   |         |         |         |         |         |         |         |         |         |         |         |             |
| AO | SCWEQI<br>PCB                     | DTB     | ADB     |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 06 | SCEQD<br>PCB                      | DTB     | ADB     | ♦ SPB   |         |         |         |         |         |         |         |         |         |         |         |             |
| 80 | SCEQI<br>PCB                      | DTB     | ADB     | ♦ SPB   |         |         |         |         |         |         |         |         |         |         |         |             |
| 70 |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 09 |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 50 |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 40 |                                   |         |         |         |         |         |         |         |         |         |         |         |         |         |         |             |
| 30 | MOVSWD                            | 1       |         |         |         | 1       | 1       |         |         |         |         |         |         | 1       | :  :    |             |
| 20 | DWSVOM: IWSVOM                    |         |         |         |         |         |         |         |         |         |         |         |         |         |         | <b>→→</b> I |
| 10 | MOVSD +                           |         | 1       |         |         | 1       | а       |         | 1       |         | α       | 1       | 1       | Ф       |         |             |
| 00 | MOVSI : I<br>PCB,PCB              | PCB,DTB | PCB,ADB | PCB,SPB | DTB,PCB | DTB,DTB | DTB,ADB | DTB,SPB | ADB,PCB | ADB,DTB | ADB,ADB | ADB,SPB | SPB,PCB | SPB,DTB | SPB,ADB | V SPB,SPB   |
|    | 0+                                | +1      | +2      | +3      | +4      | +5      | 9+      | +7      | +8      | 6+      | + A     | + B     | O<br>+  | 4 D     | +<br>E  | +<br>+      |

Table B.9-5 2-byte Instruction Map (first byte = 6F<sub>H</sub>)

| P  |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
|----|--------------------------|--------------|------------------------|--------------|--------------------------------|---------------|--------------------|-----------|------------------------|------|------------------------------------|--------|------------------------------------|--------------|------------------------------------|---------------|
| EO |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| D0 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 00 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| B0 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| AO |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 06 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 80 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 02 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 09 |                          |              |                        |              |                                |               |                    |           | MUL                    | MULW | DIVU                               |        |                                    |              |                                    |               |
| 50 |                          |              |                        |              |                                |               |                    |           |                        |      |                                    |        |                                    |              |                                    |               |
| 40 | MOV A,<br>@RL0+d8        |              | ®RL1 MOV A,<br>®RL1+d8 |              | @RL2 MOV A,<br>@RL2+d8         |               | ®RL3 MOV A,        |           | @RL MOVW A,<br>@RL0+d8 |      | MOVW @RL MOVW A,<br>1+d8,A @RL1+d8 |        | MOVW A,<br>@RL2+d8                 |              | MOVW A,<br>@RL3+d8                 |               |
| 30 | MOV @RL0 MOV<br>+d8,A @F |              | MOV 6<br>+d8,A         | :            | MOV (                          |               | MOV (+             |           | MOVW @RL<br>0+d8,A     |      | MOVW @RL<br>1+d8,A                 |        | MOVW @RL MOVW A,<br>2+d8,A @RL2+d8 |              | MOVW @RL MOVW A,<br>3+d8,A @RL3+d8 |               |
| 20 | MOVX A,<br>@RL0+d8       |              | MOVX A,<br>@RL1+d8     |              | MOVX A, MOV (<br>@RL2+d8 +d8,A |               | MOVX A,<br>@RL3+d8 |           |                        |      |                                    |        | LSL<br>A,R0                        | NRML<br>A,R0 | ASR<br>A,R0                        | LSR<br>A,R0   |
| 10 | MOV<br>DTB,A             | MOV<br>ADB,A | MOV<br>SSB,A           | MOV<br>USB,A | 10V<br>DPR,A                   | nov<br>@al,ah | MOVX<br>A,@A       | <u> </u>  |                        |      |                                    |        | LSLL<br>A,R0                       | MOV<br>@     |                                    | LSRL<br>A,R0  |
| 00 | MOV<br>A,DTB             | MOV<br>A,ADB | MOV A,SSB              | MOV<br>A,USB | MOV N                          | MOV<br>A,@A   | MOV<br>A,PCB       | ROLC<br>A |                        |      |                                    |        | LSLW<br>A,R0                       | MOVW<br>A,@A | ASRW<br>A,R0                       | LSRW<br>A,R0  |
|    | 0+                       | +            | +2                     | e<br>+       | +                              | +2            | 9+                 | +7        | 8<br>+                 | 6+   | +<br>+                             | +<br>B | )<br>+                             | Q+           | Ш<br>+                             | <b>ц</b><br>+ |

Table B.9-6 ea Instruction 1 (first byte =  $70_H$ )

|               | 00      | 10        | 20      | 30       | 40         | 50        | 60      | 70        | 80      | 90       | A0      | B0       | 00      | D0       | E0         | F0       |
|---------------|---------|-----------|---------|----------|------------|-----------|---------|-----------|---------|----------|---------|----------|---------|----------|------------|----------|
|               |         |           |         |          | CWBNE 1    | CWBNE 1   |         |           |         |          |         |          |         |          | CBNE       | CBNE ↓   |
| - AI          | ADDL    | ADDL A,   | SUBL    | SUBL A,  | RW0,       | @RW0+d8,  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R0,        | @RW0+d8, |
| j             | A,RL0   | @RW0+d8   | A,RL0   | @RW0+d8  | #16,rel    | #16,rel   | A,RL0   | @RW0+d8   | A,RL0   | @RW0+d8  | A,RL0   | @RW0+d8  | A,RL0   | @RW0+d8  | #8,re      | #8,rel   |
| - V           | ADDL    | ADDL A,   | SUBL    | SUBL A,  | RW1,       | @RW1+d8,  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | H,         | @RW1+d8, |
| _             | A,RL0   | @RW1+d8   | A,RL0   | @RW1+d8  | #16,rel    | #16,rel   | A,RL0   | @RW1+d8   | A,RL0   | @RW1+d8  | A,RL0   | @RW1+d8  | A,RL0   | @RW1+d8  | #8,re      | #8,rel   |
|               | ADDL    |           |         |          | RW2,       | @RW2+d8,  | CMPL    | :CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R2,        | @RW2+d8, |
| , i           | A,RL1   | @RW2+d8   | A,RL1   | @RW2+d8  | #16,rel    | #16,rel   | A,RL1   | @RW2+d8   | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8  | A,RL1   | @RW2+d8  | #8,rel     | #8,rel   |
|               | ADDL    | ADDL A,   |         |          | RW3,       | @RW3+d8,  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R3,        | @RW3+d8, |
| າ :           | A,RL1   | :@RW3+d8  | A,RL1   | :@RW3+d8 | #16,rel    | #16,rel   | A,RL1   | @RW3+d8   | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | A,RL1   | @RW3+d8  | #8,rel     | #8,rel   |
| Α.            |         | ADDL A,   |         | SUBL A,  | RW4,       | @RW4+d8,  | CMPL    | CMPL A,   |         | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R4,        | @RW4+d8, |
| 4             | A,RL2   | @RW4+d8   | A,RL2   | @RW4+d8  | #16,rel    | #16,rel   | A,RL2   | @RW4+d8   | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | A,RL2   | @RW4+d8  | #8,rel     | #8,rel   |
|               | ADDL    |           |         | SUBL A,  | RW5,       | @RW5+d8,  | CMPL    | :CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | 132        | @RW5+d8, |
| :             | A,RL2   | :@RW5+d8  | A,RL2   | @RW5+d8  | #16,rel    | #16,rel   | A,RL2   | @RW5+d8   | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | A,RL2   | @RW5+d8  | #8,rel     | #8,rel   |
|               | ADDL    |           |         | SUBL A,  | RW6,       | @RW6+d8,  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R6,        | @RW6+d8, |
| 9             | A,RL3   |           | A,RL3   | @RW6+d8  | #16,rel    | #16,rel   | A,RL3   | @RW6+d8   | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | A,RL3   | @RW6+d8  | #8,rel     | #8,rel   |
|               |         | ADDL A,   |         | SUBL A,  | RW7,       | @RW7+d8,  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | R7,        | @RW7+d8, |
|               | A,RL3   | :@RW7+d8  | A,RL3   | :@RW7+d8 | #16,rel    | #16,rel   | A,RL3   | :@RW7+d8  | A,RL3   | @RW7+d8  | A,RL3   | :@RW7+d8 | A,RL3   | @RW7+d8  | #8,rel     | #8,rel   |
|               | ADDL    |           | SUBL    | SUBL A,  | @RW0,      | @RW0+d16  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | @RW0,      | @RW0+d16 |
|               | A,@RW0  | @RW0+d16  | A,@RW0  | @RW0+d16 | #16,rel    | , #16,rel | A,@RW0  | @RW0+d16  | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | #8,rel     | ,#8,re   |
|               | ADDL    | ADDL A,   | SUBL    | SUBL A,  | @RW1,      | @RW1+d16  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | @RW1,      | @RW1+d16 |
| ວ<br>ກ        | RW1     | @RW1+d16  | A,@RW1  | @RW1+d16 | #16,rel    | , #16,rel | A,@RW1  | @RW1+d16  | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | #8,rel     | ,#8,rel  |
|               | ADDL    |           |         |          | @RW2,      | @RW2+d16  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | @RW2,      | @RW2+d16 |
| ₹             | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16 | #16,rel    | , #16,rel | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | #8,rel     | ,#8,rel  |
|               | DDL     |           |         |          | @RW3,      | @RW3+d16  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | @RW3,      | @RW3+d16 |
| <u> </u>      | A,@RW3  | :@RW3+d16 | A,@RW3  |          | #16,rel    | , #16,rel | A,@RW3  | :@RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | #8,rel     | ,#8,re   |
|               | DOL     |           | SUBL    | SUBL A,  | Use        | @RW0+RW7  |         | CMPL A,   |         | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | Use        | @RW0+RW7 |
| <u>.</u><br>ن | A,@RW0+ | -RW7      | A,@RW0+ | @RW0+RW7 | prohibited | , #16,rel | A,@RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | prohibited | ,#8,re   |
|               | ADDL    | ADDL A,   | SUBL    | SUBL A,  | Use        | @RW1+RW7  | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | Use        | @RW1+RW7 |
|               | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7 | prohibited | , #16,rel | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | prohibited | #8,rel   |
|               | ADDL    | ADDL A,   | SUBL    | SUBL A,  | Use        | @PC+d16,  | CMPL    | :CMPL A,  | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | Use        | @PC+d16, |
| ш             | A,@RW2+ |           | A,@RW2+ |          | prohibited | #16,rel   | A,@RW2+ | @PC+d16   | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | prohibited | #8,rel   |
|               | ADDL    | ADDL A,   | SUBL    | SUBL A,  | Use        | addr16,   | CMPL    | CMPL A,   | ANDL    | ANDL A,  | ORL     | ORL A,   | XORL    | XORL A,  | Use        | addr16,  |
| <u>.</u><br>+ | A,@RW3+ | addr16    | A,@RW3+ | addr16   | prohibited | #16,rel   | A,@RW3+ | addr16    | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | prohibited | #8,re    |

Table B.9-7 ea Instruction 2 (first byte = 71<sub>H</sub>)

|          | 00     | 10         | 20     | 30         | 40       | 50       | 09    | 70        | 80      | 06        | A0      | B0        | 00       | DO        | E0      | F0        |
|----------|--------|------------|--------|------------|----------|----------|-------|-----------|---------|-----------|---------|-----------|----------|-----------|---------|-----------|
| -        | JMPP   | -JMPP      | CALLP  | CALLP      | INCL     | INCL     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | :MOVL @R  | MOV      | :MOV @R   | MOVEA   | MOVEA A,  |
| o<br>+   | @RL0   | @@RW0+d8   | @RL0   | @@RW0+d8   | RLO      | @RW0+d8  | 品     | @RW0+d8   | A,RL0   | @RW0+d8   | RL0,A   | W0+d8,A   | R0,#8    | W0+d8,#8  | A,RW0   | @RW0+d8   |
| -        | JMPP   |            | CALLP  | CALLP      | INCL     | NOL      | DECL  |           | MOVL    | MOVL A,   | MOVL    | :MOVL @R  | MOV      | :MOV @R   | MOVEA   | MOVEA A,  |
| +        | @RL0   | @@RW1+d8   | @RL0   | @@RW1+d8   | RLO      | @RW1+d8  | RLO   | @RW1+d8   | A,RL0   | @RW1+d8   | RL0,A   | W1+d8,A   | R1,#8    | .W1+d8,#8 | A,RW1   | @RW1+d8   |
| -        | JMPP   |            | CALLP  | CALLP      | INCL     | INCL     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,  |
| z<br>+   | @RL1   | @@RW2+d8   | @RL1   | @@RW2+d8   | <u>F</u> | @RW2+d8  | 7     | @RW2+d8   | A,RL1   | @RW2+d8   | RL1,A   | :W2+d8,A  | R2,#8    | .W2+d8,#8 | A,RW2   | @RW2+d8   |
| 4        | JMPP   |            | CALLP  | CALLP      | INCL     | INCL     | DECL  |           | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R    | MOVEA   | MOVEA A,  |
| o<br>ا-  | @RL1   | @@RW3+d8   | @RL1   | @@RW3+d8   | 균        | @RW3+d8  | 균     | @RW3+d8   | A,RL1   | @RW3+d8   | RL1,A   | :W3+d8,A  | R3,#8    | W3+d8,#8  | A,RW3   | @RW3+d8   |
| -        | JMPP   |            | CALLP  | CALLP      | INCL     | INCL     | DECL  |           | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | :MOV @R   | MOVEA   | MOVEA A,  |
| +        | @RL2   | @@RW4+d8   | @RL2   | @@RW4+d8   | RL2      | @RW4+d8  | RL2   | @RW4+d8   | A,RL2   | @RW4+d8   | RL2,A   | W4+d8,A   | R4,#8    | W4+d8,#8  | A,RW4   | @RW4+d8   |
|          | JMPP   |            |        | CALLP      | NOL      | INCL     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R    |         | MOVEA A,  |
| ი<br>+   | @RL2   | @@RW5+d8   | @RL2   | @@RW5+d8   | RL2      | @RW5+d8  | RL2   | @RW5+d8   | A,RL2   | @RW5+d8   | RL2,A   | W5+d8,A   | R5,#8    | .W5+d8,#8 | A,RW5   | @RW5+d8   |
| -        | JMPP   |            | CALLP  | CALLP      | NOL.     | INCL     | DECL  |           | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @R    |         | MOVEA A,  |
| 9+       | @RL3   | :@@RW6+d8  | @RL3   | @@RW6+d8   | RL3      | @RW6+d8  | RL3   | @RW6+d8   | A,RL3   | @RW6+d8   | RL3,A   | W6+d8,A   | H6,#8    | :W6+d8,#8 | A,RW6   | @RW6+d8   |
|          | JMPP   |            | CALLP  |            | INCL     | JoN:     | DECL  | :DECL     | MOVL    | :MOVL A,  | MOVL    | :MOVL @R  | MOV      | :MOV @R   | MOVEA   | MOVEA A,  |
| + 7      | @RL3   | @@RW7+d8   | @RL3   | @@RW7+d8   | RL3      | @RW7+d8  | RL3   | @RW7+d8   | A,RL3   | @RW7+d8   | RL3,A   | W7+d8,A   | R7,#8    | W7+d8,#8  | A,RW7   | @RW7+d8   |
| -        | JMPP   | JMPP @     | CALLP  | CALLP @    | NOL      | NCL.     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | :MOVL @R  | MOV      | MOV @RW   | MOVEA   | MOVEA A,  |
| + 8      | @@RW0  | @RW0+d16   | @@RW0  | @RW0+d16   | @RW0     | @RW0+d16 | @RW0  | @RW0+d16  | A,@RW0  | :@RW0+d16 | @RW0,A  | :W0+d16,A | @RW0,#8  | 0+d16,#8  | A,@RW0  | @RW0+d16  |
|          | JMPP   | JMPP @     | CALLP  | CALLP @    | NOL      | INCL     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,  |
| + 9      | @@RW1  | @RW1+d16   | @@RW1  | @RW1+d16   | @RW1     | @RW1+d16 | @RW1  | :@RW1+d16 | A,@RW1  | :@RW1+d16 | @RW1,A  | :W1+d16,A | @RW1,#8  | :1+d16,#8 | A,@RW1  | @RW1+d16  |
|          | JMPP   | JMPP @     | CALLP  | CALLP @    | INCL     | INCL     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,  |
| <b>∀</b> | @@RW2  | : @RW2+d16 | @@RW2  | : @RW2+d16 | @RW2     | @RW2+d16 | @RW2  | :@RW2+d16 | A,@RW2  | :@RW2+d16 | @RW2,A  | :W2+d16,A | @RW2,#8  | :2+d16,#8 | W2      | :@RW2+d16 |
|          | JMPP   | : JMPP @   | CALLP  | CALLP @    | INCL     | INCL     | DECL  |           | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | :MOV @RW  |         | MOVEA A,  |
| 4 B      | @@RW3  |            | @@RW3  | @RW3+d16   | @RW3     | @RW3+d16 | @RW3  | @RW3+d16  | A,@RW3  | @RW3+d16  | @RW3,A  | W3+d16,A  | @RW3,#8  | 3+d16,#8  | A,@RW3  | @RW3+d16  |
|          | JMPP   | : JMPP @   |        | CALLP @    | INCL     | INCL.    | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW   |         | MOVEA A,  |
| ر<br>د   | @@RW0+ | @RW0+RW7   | @@RW0+ | @RW0+RW7   | @RW0+    | @RW0+RW7 | @RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7  | @RW0+,A | W0+RW7,A  | @RW0+,#8 | 0+RW7,#8  | A,@RW0+ | @RW0+RW7  |
|          | JMPP   | JMPP @     | CALLP  | CALLP @    | INCL     | NCL.     | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @R   | MOV      | MOV @RW   | MOVEA   | MOVEA A,  |
| + D      | @@RW1+ |            | @@RW1+ | @RW1+RW7   | @RW1+    | @RW1+RW7 | @RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7  | @RW1+,A | :W1+RW7,A | @RW1+,#8 | :1+RW7,#8 | A,@RW1+ | @RW1+RW7  |
|          | JMPP   | JMPP       | CALLP  | CALLP      | INCL     | NCL      | DECL  | DECL      | MOVL    | MOVL A,   | MOVL    | MOVL @P   | MOV      | MOV @P    | MOVEA   | MOVEA A,  |
| + E      | @@RW2+ | :@@PC+d16  | @@RW2+ | @@PC+d16   | @RW2+    | @PC+d16  | @RW2+ | :@PC+d16  | A,@RW2+ | :@PC+d16  | @RW2+,A | :C+d16,A  | @RW2+,#8 | :C+d16,#8 | A,@RW2+ | @PC+d16   |
|          | JMPP   | : JMPP     | CALLP  | CALLP      | INCL     | NCL      | DECL  | DECL      | MOVL    | :MOVL A,  | MOVL    | :MOVL     | MOV      | :MOV      | MOVEA   | MOVEA A,  |
| +        | @@RW3+ | @addr16    | @@RW3+ | @addr16    | @RW3+    | addr16   | @RW3+ | addr16    | A,@RW3+ | addr16    | @RW3+,A | addr16,A  | @RW3+,#8 | addr16,#8 | A,@RW3+ | addr16    |

Table B.9-8 ea Instruction 3 (first byte =  $72_H$ )

| + 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | POLC  © RW0-d8  ROLC  © RW1-d8  ROLC  © RW2-d8  ROLC  © RW3-d8  ROLC  © RW4-d8  ROLC  © RW4-d8  ROLC  © RW6-d8 | RORC<br>R0 |          |          |            |       |          |         |          |         |           |         | 8        | EU      | -        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|------------|----------|----------|------------|-------|----------|---------|----------|---------|-----------|---------|----------|---------|----------|
| HOLC HOLC HOLC HOLC HOLC HOLC HOLC HOLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | © RW0+d8 30LC © RW1+d8 30LC © RW2+d8 30LC © RW3+d8 60LC © RW4+d8 60LC © RW4+d8 60LC                            | 2          | RORC     | NC       | INC        | DEC   | DEC      | MOV     | MOV A,   | MOV     | :MOV @R   | MOVX    | MOVX A,  | ХСН     | XCH A,   |
| HOLC R4 HOLC R5 HOLC R6 HOLC R6 HOLC R7 HOLC R7 HOLC GRW0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | PRW1+d8 POLC POLC POLC POLC POLC POLC POLC POLC                                                                | •          | @RW0+d8  | 22       | @RW0+d8    | 2     | @RW0+d8  | A,R0    | @RW0+d8  | R0,A    | W0+d8,A   | A,R0    | @RW0+d8  | A,R0    | @RW0+d8  |
| HOLC RS ROLC RS HOLC R | ® RW1+48 3-0LC 8 RW2+48 3-0LC 9 RW4+48 ROLC @ RW5+48 ROLC @ RW5+48                                             | RORC       |          | <u>N</u> | INC        | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| 2 ROLC R2 ROLC R3 ROLC R6 R0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 9 RW2+48 3-01.C 9 RW3+48 3-01.C 6 RW3+48 ROLC 9 RW5+48 ROLC 8 RW5+48                                           | æ          | @RW1+d8  | 듄        | @RW1+d8    | 듄     | @RW1+d8  | A,R1    | @RW1+d8  | R1,A    | W1+d8,A   | A,R1    | @RW1+d8  | A,R1    | @RW1+d8  |
| 3 ROLC RS RS RS ROLC RS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ®RW2+d8 3OLC 3OLC ®RW4+d8 ROLC ®RNC+d8 ROLC ®RW5+d8                                                            | RORC       | RORC     | <u>N</u> | INC        | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| 3 ROLC R3 F3 F8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 30LC<br>30RW3+48<br>30LC<br>80RW5+48<br>30LC<br>60RW5+48                                                       | . Z        | @RW2+d8  | 낊        | @RW2+d8    | 낊     | @RW2+d8  | A,R2    | @RW2+d8  | R2,A    | W2+d8,A   | A,R2    | @RW2+d8  | A,R2    | @RW2+d8  |
| 5 ROLC R6 ROCC | ®RW3+d8 3OLC @RW4+d8 GRW5+d8 ROLC @RW6+d8                                                                      | RORC       | RORC     | <u>8</u> | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     |           | MOVX    | MOVX A,  |         | XCH A,   |
| # ROLC R4  FOLC R5  FOLC R6  F | 3OLC @RW4+d8 3OLC @RW5+d8 ROLC @RW6+d8                                                                         | 23         | @RW3+d8  | 23       | @RW3+d8    | 22    | @RW3+d8  | A,R3    | @RW3+d8  | R3,A    | W3+d8,A   | A,R3    | @RW3+d8  | A,R3    | @RW3+d8  |
| 5 HOLC R5 HOLC R6 HOLC R7 HOLD | @RW4+d8<br>3OLC<br>@RW5+d8<br>ROLC<br>@RW6+d8                                                                  | RORC       | RORC     | <u>S</u> | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     |           | MOVX    | MOVX A,  | XCH     | XCH A,   |
| FOLC RS FOLC RS FOLC RS FOLC RY FOLC R | 3OLC<br>@RW5+d8<br>ROLC<br>@RW6+d8                                                                             | P4         | @RW4+d8  | *        | @RW4+d8    | *     | @RW4+d8  | A,R4    | @RW4+d8  | R4,A    | W4+d8,A   | A,R4    | @RW4+d8  | A,R4    | @RW4+d8  |
| FOLC RE ROLC ROLC ROLC ROLC ROLC ROLC ROLC ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | @RW5+d8<br>ROLC<br>@RW6+d8                                                                                     |            | RORC     | <u>2</u> | NC         | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| FOLC RE T ROLC RY ROLC RY ROLC RY ROLC RY ROLC RY ROLC RY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 3OLC<br>@RW6+d8                                                                                                | <br>R2     | @RW5+d8  | 32       | @RW5+d8    | 윤     | @RW5+d8  | A,R5    | @RW5+d8  | R5,A    | W5+d8,A   | A,R5    | @RW5+d8  | A,R5    | @RW5+d8  |
| 6 ROLC R7 ROLC ROLC ROLC ROLC ROLC ROLC ROLC ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | @RW6+d8                                                                                                        |            |          | <u>S</u> | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| 7 ROLC R7 ROLC 8 @RW0 9 ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                | P8         | @RW6+d8  | Ъ.       | @RW6+d8    | P8    | @RW6+d8  | A,R6    | @RW6+d8  | R6,A    | .W6+d8,A  | A,R6    | @RW6+d8  | A,R6    | @RW6+d8  |
| 8 @RW0 ROLC 8 @RW0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 30LC                                                                                                           |            | RORC     | <u>N</u> | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| 8 @RW0<br>ROLC<br>9 @BW44                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | @RW7+d8                                                                                                        | 2          | @RW7+d8  | R7       | @RW7+d8    | R7    | @RW7+d8  | A,R7    | @RW7+d8  | R7,A    | W7+d8,A   | A,R7    | @RW7+d8  | A,R7    | @RW7+d8  |
| 8 @RW0<br>9 BDLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                | RORC       | RORC     | <u>N</u> | <u>N</u> C | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| ROLC<br>9 BDM1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | @RW0+d16                                                                                                       | @RW0       | @RW0+d16 | @RW0     | @RW0+d16   | @RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,A  | W0+d16,A  | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 |
| . PMIG®                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ROLC                                                                                                           | RORC       | RORC     | <u>2</u> | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| • • :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | @RW1+d16                                                                                                       | @RW1       | @RW1+d16 | @RW1     | @RW1+d16   | @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,A  | :W1+d16,A | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | NC       | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| +A @RW2 : @                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | @RW2+d16                                                                                                       | @RW2       | @RW2+d16 | @RW2     | @RW2+d16   | @RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,A  | W2+d16,A  | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | NC       | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| + B @RW3 : @                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | @RW3+d16                                                                                                       | @RW3       | @RW3+d16 | @RW3     | @RW3+d16   | @RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | @RW3,A  | W3+d16,A  | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | <u>N</u> | <u>N</u> C | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| • • • • •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | @RW0+RW7                                                                                                       | @RW0+      | @RW0+RW7 | @RW0+    | @RW0+RW7   | @RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A  | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | NC<br>NC | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @R    | MOVX    | MOVX A,  | XCH     | XCH A,   |
| + D @RW1+ ; @                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | @RW1+RW7                                                                                                       | @RW1+      | @RW1+RW7 | @RW1+    | @RW1+RW7   | @RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,A | :W1+RW7,A | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | NC       | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV @P    | MOVX    | MOVX A,  | XCH     | XCH A,   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | @PC+d16                                                                                                        | @RW2+      | @PC+d16  | @RW2+    | @PC+d16    | @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,A | C+d16,A   | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  |
| ROLC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ROLC                                                                                                           | RORC       | RORC     | NC       | NC<br>NC   | DEC   | DEC      | MOV     | MOV A,   | MOV     | MOV       | MOVX    | MOVX A,  | XCH     | XCH A,   |
| + F @RW3+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | addr16                                                                                                         | @RW3+      | addr16   | @RW3+    | addr16     | @RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,A | addr16,A  | A,@RW3+ | addr16   | A,@RW3+ | addr16   |

Table B.9-9 ea Instruction 4 (first byte =  $73_H$ )

| 1 + 0 + 0 + 0 1 1 1 1 1 1 1 1 1 1 1 1 1 | U @RWO @   |          |        | 3        | 40    | 20       | 90    | )        | 8       | 06       | AO      | DQ         | 3        | 3          | LO      | 2        |
|-----------------------------------------|------------|----------|--------|----------|-------|----------|-------|----------|---------|----------|---------|------------|----------|------------|---------|----------|
|                                         |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | : MOVW @R  | MOVW     | MOVW @RW   | хснм    | XCHW A,  |
|                                         |            | @@RW0+d8 | @RW0   | @@RW0+d8 | RW0   | @RW0+d8  | RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | RW0,A   | W0+d8,A    | RW0,#16  | 0+d8,#16   | A,RW0   | @RW0+d8  |
|                                         |            |          | CALL   | CALL     | INCW  | INCW     | DECW  |          | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | N.         | XCHW    | XCHW A,  |
| N 60                                    | @RW1 : (   | @@RW1+d8 | @RW1   | @@RW1+d8 | RW1   | @RW1+d8  | RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | RW1,A   | W1+d8,A    | RW1,#16  | 1+d8,#16   | A,RW1   | @RW1+d8  |
| N m                                     |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW @RW   | XCHW    | XCHW A,  |
| e<br>e                                  | @RW2 : @   | @@RW2+d8 | @RW2   | @@RW2+d8 | RW2   | @RW2+d8  | RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | RW2,A   | W2+d8,A    | RW2,#16  | 2+d8,#16   | A,RW2   | @RW2+d8  |
| <u> </u>                                |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | 3//        | XCHW    | XCHW A,  |
|                                         | @RW3 : (   | @@RW3+d8 | @RW3   | @@RW3+d8 | RW3   | @RW3+d8  | RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | RW3,A   | W3+d8,A    | RW3,#16  | 3+d8,#16   | A,RW3   | @RW3+d8  |
| JMP                                     | ····       | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | 3W         | XCHW    | XCHW A,  |
| +                                       | @RW4 (     | @@RW4+d8 | @RW4   | @@RW4+d8 | RW4   | @RW4+d8  | RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | RW4,A   | W4+d8,A    | RW4,#16  | 4+d8,#16   | A,RW4   | @RW4+d8  |
| JMP                                     |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW @RW   | XCHW    | XCHW A,  |
| c<br>+                                  | @RW5 : @   | @@RW2+d8 | @RW5   | @@RW2+d8 | RW5   | @RW5+d8  | RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | RW5,A   | W5+d8,A    | RW5,#16  | 5+d8,#16   | A,RW5   | @RW5+d8  |
| JMP                                     |            |          | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW @RW   | XCHW    | XCHW A,  |
| 9 +                                     | @RW6 :     | @@RW6+d8 | @RW6   | @@RW6+d8 | RW6   | @RW6+d8  | RW6   | @RW6+d8  | A,RW6   | @RW6+d8  | RW6,A   | W6+d8,A    | RW6,#16  | 6+d8,#16   | A,RW6   | @RW6+d8  |
| JMP .                                   |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW @RW   | XCHW    | XCHW A,  |
| /+                                      | @RW7 (     | @@RW7+d8 | @RW7   | @@RW7+d8 | RW7   | @RW7+d8  | RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | RW7,A   | W7+d8,A    | RW7,#16  | 7+d8,#16   | A,RW7   | @RW7+d8  |
| JMP                                     |            | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    |          | MOVW@RW0   | XCHW    | XCHW A,  |
| ©<br>>><br>+                            | @@RW0 (    | @RW0+d16 | @@RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,A  | W0+d16,A   | @RW0,#16 | +d16,#16   | A,@RW0  | @RW0+d16 |
| JMP                                     |            | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW@RW1   | XCHW    | XCHW A,  |
| ®<br>6+                                 | @@RW1 : (  | @RW1+d16 | @@RW1  | @RW1+d16 | @RW1  | @RW1+d16 | @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,A  | W1+d16,A   | @RW1,#16 | +d16,#16   | A,@RW1  | @RW1+d16 |
| JMP                                     | ·          | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW@RW2   | XCHW    | XCHW A,  |
| ®<br>+                                  | @@RW2 : (  |          | @@RW2  | @RW2+d16 | @RW2  | @RW2+d16 | @RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,A  | W2+d16,A   | @RW2,#16 |            | A,@RW2  | @RW2+d16 |
| JMP                                     |            | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW     | MOVW@RW3   | XCHW    | XCHW A,  |
| ®<br>+ B                                | @@RW3 : (  |          | @@RW3  | @RW3+d16 | @RW3  | @RW3+d16 | @RW3  |          | A,@RW3  | @RW3+d16 | @RW3,A  | W3+d16,A   | @RW3,#16 | +d16,#16   | A,@RW3  | @RW3+d16 |
| JMP                                     |            | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW @   | MOVW@RW0   | XCHW    | XCHW A,  |
| သ +                                     |            |          | @@RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,A | : W0+RW7,A | RW0+,#16 |            | _       | @RW0+RW7 |
|                                         | U.: AMD    | JMP @    | CALL   | CALL @   | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @R    | MOVW @   | MOVW@RW1   | XCHW    | XCHW A,  |
| )                                       | @@RW1+ : ( | @RW1+RW7 | @@RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,A | : W1+RW7,A | RW1+,#16 | +RW7,#16   | A,@RW1+ | @RW1+RW7 |
| JMP                                     | ,          | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW @P    | MOVW @   | MOVW @PC   | XCHW    | XCHW A,  |
| + E                                     |            |          | @@RW2+ | @@PC+d16 | @RW2+ | @PC+d16  | @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,A |            | RW2+,#16 | +416,#16   | A,@RW2+ | @PC+d16  |
| - JMP                                   |            | JMP      | CALL   | CALL     | INCW  | INCW     | DECW  | DECW     | MOVW    | MOVW A,  | MOVW    | MOVW       | MOVW @   | MOVW       | XCHW    | XCHW A,  |
| )<br>                                   | @@RW3+     | @addr16  | @@RW3+ | @addr16  | @RW3+ | addr16   | @RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,A | addr16,A   | RW3+,#16 | addr16,#16 | A,@RW3+ | addr16   |

Table B.9-10 ea Instruction 5 (first byte =  $74_H$ )

|        | 00      | 10       | 20      | 30       | 40      | 50       | 09      | 70       | 08      | 06       | AO      | B0         | 00      | DO       | E0      | F0         |
|--------|---------|----------|---------|----------|---------|----------|---------|----------|---------|----------|---------|------------|---------|----------|---------|------------|
| -      | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| o<br>F | A,R0    | @RW0+d8    | A,R0    | @RW0+d8  | R0,r    | RW0+d8,r   |
| -      | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OB.     | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| +      | A,R1    | @RW1+d8  | A,R1    | : @RW1+d8  | A,R1    | @RW1+d8  | R1,r    | RW1+d8,r   |
|        | ADD     |          | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | S S     | OB A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| 7 +    | A,R2    | @RW2+d8    | A,R2    | @RW2+d8  | R2,r    | RW2+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| o<br>F | A,R3    | @RW3+d8    | A,R3    | @RW3+d8  | R3,r    | RW3+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| +      | A,R4    | @RW4+d8    | A,R4    | @RW4+d8  | R4,r    | RW4+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | OR      | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| ¢<br>+ | A,R5    | @RW5+d8    | A,R5    | @RW5+d8  | R5,r    | RW5+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | e<br>B  | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| φ<br>+ | A,R6    | @RW6+d8    | A,R6    | @RW6+d8  | R6,r    | RW6+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | 8       | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| + 1    | A,R7    | @RW7+d8    | A,R7    | @RW7+d8  | R7,r    | RW7+d8,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | В       | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| æ<br>+ | A,@RW0  | @RW0+d16   | A,@RW0  | @RW0+d16 | @RW0,r  | W0+d16,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | 8       | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| 6+     | A,@RW1  | @RW1+d16 | A,@RW1  | : @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,r  | . W1+d16,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | SH.     | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| + A    | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | @RW2,r  | . W2+d16,r |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | В       | OB A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| H<br>H | A,@RW3  | @RW3+d16   | A,@RW3  | @RW3+d16 | @RW3,r  | W3+d16,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | В       | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| ၁<br>+ | A,@RW0+ | @RW0+RW7 |         | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | @RW0+,r | W0+RW7,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   |         | AND A,   | В       | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ @R    |
| 4 D    | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | @RW1+,r | W1+RW7,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | Ж       | OB A,      | XOR     | XOR A,   | DBNZ    | DBNZ @     |
| ш<br>+ | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16  | @RW2+,r | PC+d16,r   |
|        | ADD     | ADD A,   | SUB     | SUB A,   | ADDC    | ADDC A,  | CMP     | CMP A,   | AND     | AND A,   | SH.     | OR A,      | XOR     | XOR A,   | DBNZ    | DBNZ       |
| L<br>+ | A,@RW3+ | addr16     | A,@RW3+ | addr16   | @RW3+,r | addr16,r   |

Table B.9-11 ea Instruction 6 (first byte =  $75_H$ )

|            | 00       | 10         | 20       | 30         | 40      | 50       | 09    | 70       | 80       | 06         | A0      | B0         | 00      | D0       | E0    | F0         |
|------------|----------|------------|----------|------------|---------|----------|-------|----------|----------|------------|---------|------------|---------|----------|-------|------------|
| +          | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | : AND @R   | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| ><br>+     | R0,A     | W0+d8,A    | R0,A     | W0+d8,A    | A,R0    | @RW0+d8  | 2     | @RW0+d8  | R0,A     | W0+d8,A    | R0,A    | W0+d8,A    | R0,A    | W0+d8,A  | 2     | @RW0+d8    |
| -          | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | : AND @R   | OR      | : OR @R    | XOR     | XOR @R   | NOT   | NOT:       |
| +          | R1,A     | . W1+d8,A  | R1,A     | W1+d8,A    | A,R1    | @RW1+d8  | 윤     | @RW1+d8  | R1,A     | W1+d8,A    | R1,A    | W1+d8,A    | R1,A    | W1+d8,A  | 퓬     | : @RW1+d8  |
| -          | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      |          | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| 7 +        | R2,A     | W2+d8,A    | R2,A     | . W2+d8,A  | A,R2    | @RW2+d8  | R2    | @RW2+d8  | R2,A     | . W2+d8,A  | R2,A    | W2+d8,A    | R2,A    | W2+d8,A  | RS    | @RW2+d8    |
| e<br>+     | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| ი<br> -    | R3,A     | W3+d8,A    | R3,A     | W3+d8,A    | A,R3    | @RW3+d8  | R3    | @RW3+d8  | R3,A     | W3+d8,A    | R3,A    | W3+d8,A    | R3,A    | W3+d8,A  | 83    | @RW3+d8    |
| -          | ADD      | : ADD @R   | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      |          | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | : NOT      |
| +          | R4,A     | W4+d8,A    | R4,A     | W4+d8,A    | A,R4    | @RW4+d8  | P4    | @RW4+d8  | R4,A     | W4+d8,A    | R4,A    | W4+d8,A    | R4,A    | W4+d8,A  | R4    | @RW4+d8    |
|            | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT:       |
| <b>4</b> ک | R5,A     | : W5+d8,A  | R5,A     | W5+d8,A    | A,R5    | @RW5+d8  | R3    | @RW5+d8  | R5,A     | : W5+d8,A  | R5,A    | . W5+d8,A  | R5,A    | W5+d8,A  | R5    | : @RW5+d8  |
|            | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR<br>B | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| 9+         | R6,A     | . W6+d8,A  | R6,A     | W6+d8,A    | A,R6    | @RW6+d8  | Re    | @RW6+d8  | R6,A     | W6+d8,A    | R6,A    | W6+d8,A    | R6,A    | W6+d8,A  | P8    | @RW6+d8    |
|            | ADD      | ADD @R     |          | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| <i>t</i> + | R7,A     | . W7+d8,A  | R7,A     | W7+d8,A    | A,R7    | @RW7+d8  | R7    | @RW7+d8  | R7,A     | W7+d8,A    | R7,A    | W7+d8,A    | HZ,A    | W7+d8,A  | R7    | @RW7+d8    |
|            | ADD      | : ADD @R   | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | . NEG    | AND      | : AND @R   | В       | OR @R      | XOR     | XOR @R   | NOT   | : NOT      |
| 8<br>+     | @RW0,A   | : W0+d16,A | @RW0,A   | W0+d16,A   | A,@RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0,A   | W0+d16,A   | @RW0,A  | : W0+d16,A | @RW0,A  | W0+d16,A | @RW0  | : @RW0+d16 |
|            | ADD      |            |          | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | В       | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| 6<br>+     | @RW1,A   | : W1+d16,A | @RW1,A   | : W1+d16,A | A,@RW1  | @RW1+d16 | @RW1  | @RW1+d16 | @RW1,A   | : W1+d16,A | @RW1,A  | : W1+d16,A | @RW1,A  | W1+d16,A | @ RW1 | @RW1+d16   |
|            | ADD      |            | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| <b>+</b>   | @RW2,A   | : W2+d16,A | @RW2,A   | W2+d16,A   | A,@RW2  | @RW2+d16 | @RW2  | @RW2+d16 | @RW2,A   | . W2+d16,A | @RW2,A  | . W2+d16,A | @RW2,A  | W2+d16,A | @RW2  | : @RW2+d16 |
|            | ADD      | ADD @R     |          | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | :0R @R     | XOR     | XOR @R   | NOT   | : NOT      |
| 9<br>+     | @RW3,A   | . W3+d16,A | @RW3,A   | W3+d16,A   | A,@RW3  | @RW3+d16 | @RW3  | 3+d16    | @RW3,A   | W3+d16,A   | @RW3,A  | W3+d16,A   | @RW3,A  | W3+d16,A | @RW3  | @RW3+d16   |
|            | ADD      | ADD @R     |          | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | : AND @R   | OR.     | OR @R      | XOR     | XOR @R   | NOT   | : NOT      |
| ၁<br>+     | @RW0+,A  | W0+RW7,A   | @RW0+,A  | W0+RW7,A   | A,@RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+,A  | W0+RW7,A   | @RW0+,A | W0+RW7,A   | @RW0+,A | W0+RW7,A | @RW0+ | @RW0+RW7   |
|            | ADD      | ADD @R     | SUB      | SUB @R     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @R     | OR      | OR @R      | XOR     | XOR @R   | NOT   | NOT        |
| n<br>+     | @RW1+,A  | : W1+RW7,A | @RW1+,A  | : W1+RW7,A | A,@RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | @RW1+,A  | : W1+RW7,A | @RW1+,A | : W1+RW7,A | @RW1+,A | W1+RW7,A | @RW1+ | @RW1+RW7   |
|            | ADD      | ADD @P     | SUB      | SUB @P     | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND @P     | OR      | .OR @P     | XOR     | XOR @P   | NOT   | LON        |
| <b>+</b>   | @RW2+,A  | : C+d16,A  | @RW2+,A  | C+d16,A    | A,@RW2+ | @PC+d16  | @RW2+ | @PC+d16  | @RW2+,A  | C+d16,A    | @RW2+,A | C+d16,A    | @RW2+,A | C+d16,A  | @RW2+ | @PC+d16    |
|            | ADD      | ADD        | SUB      | SUB        | SUBC    | SUBC A,  | NEG   | NEG      | AND      | AND        | В       | B.         | XOR     | XOR      | NOT   | _NOT       |
| њ<br>+     | @ RW3+,A | addr16,A   | @ RW3+,A | addr16,A   | A,@RW3+ | addr16   | @RW3+ | addr16   | @ RW3+,A | addr16,A   | @RW3+,A | addr16,A   | @RW3+,A | addr16,A | @RW3+ | addr16     |

Table B.9-12 ea Instruction 7 (first byte =  $76_H$ )

|          | 00      | 10       | 20      | 30       | 40      | 50         | 09      | 70       | 08      | 06        | AO      | BO       | 00      | D0       | E0      | F0        |
|----------|---------|----------|---------|----------|---------|------------|---------|----------|---------|-----------|---------|----------|---------|----------|---------|-----------|
| -        | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| o<br>+   | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8    | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8   | A,RW0   | @RW0+d8  | A,RW0   | @RW0+d8  | RW0,r   | RW0+d8,r  |
| -        | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| -        | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8    | A,RW1   | @RW1+d8  | A,RW1   | : @RW1+d8 | A,RW1   | @RW1+d8  | A,RW1   | @RW1+d8  | RW1,r   | RW1+d8,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| 7 +      | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8    | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8   | A,RW2   | @RW2+d8  | A,RW2   | @RW2+d8  | RW2,r   | RW2+d8,r  |
| -        | ADDW    |          | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| ი<br>+   | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8    | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8   | A,RW3   | @RW3+d8  | A,RW3   | @RW3+d8  | RW3,r   | RW3+d8,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | : ADDCW A, | CMPW    | CMPW A,  | ANDW    | : ANDW A, | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| + 4      | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8    | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8   | A,RW4   | @RW4+d8  | A,RW4   | @RW4+d8  | RW4,r   | RW4+d8,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| 4 +      | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8    | A,RW5   | @RW5+d8  | A,RW5   | : @RW5+d8 | A,RW5   | @RW5+d8  | A,RW5   | @RW5+d8  | RW5,r   | RW5+d8,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| 9 +      | A,RW6   | @RW6+d8  | A,RW6   | @RW6+d8  | A,RW6   | @RW6+d8    | A,RW6   | @RW6+d8  | A,RW6   | @RW6+d8   | A,RW6   | @RW6+d8  | A,RW6   | @RW6+d8  | RW6,r   | RW6+d8,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| + 1      | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8    | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8   | A,RW7   | @RW7+d8  | A,RW7   | @RW7+d8  | RW7,r   | RW7+d8,r  |
| -        | ADDW    | ADDW A,  |         | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| 8 +      | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16   | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16  | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | @RW0,r  | W0+d16,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| 6+       | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16   | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16  | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 | @RW1,r  | W1+d16,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| <b>+</b> | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16  | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | @RW2,r  | .W2+d16,r |
|          | ADDW    | ADDW A,  |         | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| я<br>+   | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16   | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16  | A,@RW3  |          | A,@RW3  | @RW3+d16 | @RW3,r  | W3+d16,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | : ANDW A, | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| ၁<br>+   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7  | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | @RW0+,r | W0+RW7,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @R  |
| n +      | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7  | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | @RW1+,r | W1+RW7,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ @   |
| +        | A,@RW2+ | @PC+d16  | A,@RW2+ |          | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16  | A,@RW2+ | : @PC+d16 | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | @RW2+,r | PC+d16,r  |
|          | ADDW    | ADDW A,  | SUBW    | SUBW A,  | ADDCW   | ADDCW A,   | CMPW    | CMPW A,  | ANDW    | ANDW A,   | ORW     | ORW A,   | XORW    | XORW A,  | DWBNZ   | DWBNZ     |
| ц<br>+   | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16     | A,@RW3+ | addr16   | A,@RW3+ | addr16    | A,@RW3+ | addr16   | A,@RW3+ | addr16   | @RW3+,r | addr16,r  |

Table B.9-13 ea Instruction 8 (first byte =  $77_H$ )

|              | 00      | 10              | 20      | 30         | 40      | 50       | 90    | 20       | 80      | 06         | A0      | B0         | 00      | D0         | E0    | F0       |
|--------------|---------|-----------------|---------|------------|---------|----------|-------|----------|---------|------------|---------|------------|---------|------------|-------|----------|
| -            | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MLON  | NOTW     |
| ><br> -      | RW0,A   | W0+d8,A         | RW0,A   | W0+d8,A    | A,RW0   | @RW0+d8  | RW0   | @RW0+d8  | RW0,A   | W0+d8,A    | RW0,A   | W0+d8,A    | RW0,A   | W0+d8,A    | RW0   | @RW0+d8  |
| -            | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WLON  | WLON     |
| +            | RW1,A   | . W1+d8,A       | RW1,A   | W1+d8,A    | A,RW1   | @RW1+d8  | RW1   | @RW1+d8  | RW1,A   | W1+d8,A    | RW1,A   | W1+d8,A    | RW1,A   | . W1+d8,A  | RW1   | @RW1+d8  |
|              | ADDW    |                 |         | SUBW @R    | SUBCW   | SUBCW A, | NEGW  |          | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WLON  | WLON     |
| N<br>+       | RW2,A   | W2+d8,A         | RW2,A   | W2+d8,A    | A,RW2   | @RW2+d8  | RW2   | @RW2+d8  | RW2,A   | W2+d8,A    | RW2,A   | W2+d8,A    | RW2,A   | W2+d8,A    | RW2   | @RW2+d8  |
|              | ADDW    |                 | SUBW    |            | SUBCW   |          | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MOTW  | MLON     |
| ი<br> -      | RW3,A   | W3+d8,A         | RW3,A   | W3+d8,A    | A,RW3   | @RW3+d8  | RW3   | @RW3+d8  | RW3,A   | W3+d8,A    | RW3,A   | W3+d8,A    | RW3,A   | W3+d8,A    | RW3   | @RW3+d8  |
| -            | ADDW    |                 | SUBW    | SUBW @R    | SUBCW   |          | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WDOW  | MLON     |
| <del> </del> | RW4,A   | RW4,A : W4+d8,A | RW4,A   | W4+d8,A    | A,RW4   | @RW4+d8  | RW4   | @RW4+d8  | RW4,A   | W4+d8,A    | RW4,A   | W4+d8,A    | RW4,A   | W4+d8,A    | RW4   | @RW4+d8  |
|              | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     |         | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MOTW  | WLON     |
| ი<br>+       | RW5,A   | W5+d8,A         | RW5,A   | W5+d8,A    | A,RW5   | @RW5+d8  | RW5   | @RW5+d8  | RW5,A   | W5+d8,A    | RW5,A   | . W5+d8,A  | RW5,A   | W5+d8,A    | RW5   | @RW5+d8  |
| -            | ADDW    |                 | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  |          | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WLON  | MOTW     |
| 9            | RW6,A   | . W6+d8,A       | RW6,A   | : W6+d8,A  | A,RW6   | @RW6+d8  | RW6   | @RW6+d8  | RW6,A   | W6+d8,A    | RW6,A   | W6+d8,A    | RW6,A   | . W6+d8,A  | RW6   | @RW6+d8  |
|              | ADDW    | : ADDW @R       | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MOTW  | WDON:    |
| + 1          | RW7,A   | W7+d8,A         | RW7,A   | W7+d8,A    | A,RW7   | @RW7+d8  | RW7   | @RW7+d8  | RW7,A   | W7+d8,A    | RW7,A   | W7+d8,A    | RW7,A   | . W7+d8,A  | RW7   | @RW7+d8  |
|              | ADDW    | ADDW @R         | S: MBNS | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WDOW  | WLON     |
| ж<br>+       | @RW0,A  | W0+d16,A        | @RW0,A  | W0+d16,A   | A,@RW0  | @RW0+d16 | @RW0  | @RW0+d16 | @RW0,A  | W0+d16,A   | @RW0,A  | W0+d16,A   | @RW0,A  | W0+d16,A   | @RW0  | @RW0+d16 |
|              | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WDOW  | NOTW     |
| 6<br>+       | @RW1,A  | : W1+d16,A      | @RW1,A  | : W1+d16,A | A,@RW1  | @RW1+d16 | @RW1  | @RW1+d16 | @RW1,A  | : W1+d16,A | @RW1,A  | W1+d16,A   | @RW1,A  | : W1+d16,A | @RW1  | @RW1+d16 |
|              | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WDOW  | NOTW     |
| ¥<br>+       | V2,A    | : W2+d16,A      | @RW2,A  | W2+d16,A   | A,@RW2  | @RW2+d16 | @RW2  | @RW2+d16 | @RW2,A  | . W2+d16,A | @RW2,A  | . W2+d16,A | @RW2,A  | : W2+d16,A | @RW2  | @RW2+d16 |
|              | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | WLON  | WLON     |
| უ<br>+       | @RW3,A  | W3+d16,A        | @RW3,A  |            | A,@RW3  | @RW3+d16 | @RW3  |          | @RW3,A  | W3+d16,A   | @RW3,A  | W3+d16,A   | @RW3,A  | W3+d16,A   | @RW3  | @RW3+d16 |
| -            | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MOTW  | MDTW     |
| ၁<br>+       | @RW0+,A | : W0+RW7,A      | ∢.      | : W0+RW7,A | A,@RW0+ | @RW0+RW7 | @RW0+ | @RW0+RW7 | @RW0+,A | W0+RW7,A   | @RW0+,A | W0+RW7,A   | @RW0+,A | W0+RW7,A   | @RW0+ | @RW0+RW7 |
|              | ADDW    | ADDW @R         | SUBW    | SUBW @R    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @R    | ORW     | ORW @R     | XORW    | XORW @R    | MOTW  | WLON     |
| n<br>+       | @RW1+,A |                 | @RW1+,A | W1+RW7,A   | A,@RW1+ | @RW1+RW7 | @RW1+ | @RW1+RW7 | @RW1+,A | W1+RW7,A   | @RW1+,A | : W1+RW7,A | @RW1+,A | W1+RW7,A   | @RW1+ | @RW1+RW7 |
|              | ADDW    | ADDW @P         | SUBW    | SUBW @P    | SUBCW   | SUBCW A, | NEGW  | NEGW     | ANDW    | ANDW @P    | ORW     | ORW @P     | XORW    | XORW @P    | MOTW  | MDUM     |
| <b>Н</b>     | @RW2+,A |                 | @RW2+,A | C+d16,A    | A,@RW2+ | @PC+d16  | @RW2+ | @PC+d16  | @RW2+,A | C+d16,A    | @RW2+,A | . C+d16,A  | @RW2+,A | C+d16,A    | @RW2+ | @PC+d16  |
|              | ADDW    | : ADDW          | SUBW    | SUBW       | SUBCW   | SUBCW A, | NEGW  | : NEGW   | ANDW    | ANDW       | ORW     | ORW        | XORW    | : XORW     | WDTW  | WLON:    |
| +            | @RW3+,A | addr16,A        | @RW3+,A | addr16,A   | A,@RW3+ | addr16   | @RW3+ | addr16   | @RW3+,A | addr16,A   | @RW3+,A | addr16,A   | @RW3+,A | addr16,A   | @RW3+ | addr16   |

Table B.9-14 ea Instruction 9 (first byte =  $78_H$ )

| MULLUW         MULLUWA         MULLUWA <th< th=""><th></th><th>00</th><th>10</th><th>20</th><th>30</th><th>40</th><th>99</th><th>09</th><th>70</th><th>80</th><th>06</th><th>AO</th><th>B0</th><th>00</th><th>0G</th><th>E0</th><th>F0</th></th<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               | 00      | 10         | 20      | 30         | 40      | 99       | 09      | 70       | 80      | 06         | AO      | B0         | 00      | 0G       | E0      | F0       |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|---------|------------|---------|------------|---------|----------|---------|----------|---------|------------|---------|------------|---------|----------|---------|----------|
| A,RO         ERWO-668         A,RWO         ERWO-668         A,RWO           MULU         A,RH         B,RWI-468         A,RWI         B,RWI-468         A,RWI           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-448         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RWI           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RWI         B,RWI-468         A,RR           MULU         A,RR         B,RWI-468         A,RR         A,RR         A,RR           MULU         A,RR         B,RWI-448         A,RR         A,RR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               | MULU    | MULU A,    | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,    | DIVUW   | DIVUW A,   | NIO     | DIV A,   | MAIQ    | DIVW A,  |
| MULU         A, RMUL         MULUW         MULUW         A, RW1         A, RW1         A, RW1           MULU         A, RW2         A, RW2         BRW3-468         A, RW2         A, RW2         A, RW2           MULU         MULUW         MULUW         MULUW         A, RW3         A, RW3         A, RW3           MULU         MULU         A, RW4         BRW3-468         A, RW3         BRW3-468         A, RW3           MULU         MULU         A, RW4         BRW4-468         A, RW4         A, RW4         A, RW3           MULU         MULU         A, RW4         BRW4-468         A, RW5         BRW5-468         A, RW5           MULU         MULU         A, MULUW         MULUW         A, RW7         BRW5-468         A, RW7           MULU         A, BRW5         BRW5-468         A, RW7         BRW7-468         A, BRW7         A, BRW7           MULU         A, BRW5         BRW1-468         A, BRW5         BRW1-468         A, BRW7         A, BRW7           MULU         MULU         A, BRW4         BRW1-468         A, BRW4         A, BRW4         A, BRW4           MULU         MULU         A, BRW4         BRW1-448         A, BRW4         A, BRW4         A, BRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               | A,R0    |            | A,RW0   |            | A R0    | @RW0+d8  | A,RW0   | @RW0+d8  | A,R0    | @RW0+d8    | A,RW0   | @RW0+d8    | A,R0    | @RW0+d8  | A,RW0   | @RW0+d8  |
| ARI         GRW1+468         ARW1         GRW1+468         ARR1           MULU         ARR2         ARW2-468         ARW2         ARW2           MULU         ARR3         GRW2-468         ARR3           MULU         ARR3         GRW3-468         ARR3           MULU         ARR4         GRW4-468         ARR4           MULU         ARR4         GRW4-468         ARR4           MULU         ARR4         GRW4-468         ARR4           MULU         ARR6         GRW5-468         ARR5           MULU         ARR6         GRW5-468         ARR5           MULU         ARW1         GRW5-468         ARR5           MULU         ARW1         GRW5-468         ARR5           MULU         ARW1         GRW5-468         ARR5           MULU         ARW1         GRW7-468         ARR7           MULU         ARW1         GRW7-468         ARR7           AGRW1         GRW1-446         AGRW1         AGRW1           AGRW1         GRW1-468         AGRW1         AGRW1           AGRW1         GRW1-468         AGRW1         AGRW1           AGRW1         GRW1-468         AGRW1         AGRW1 <th>-</th> <th>MULU</th> <th></th> <th>MULUW</th> <th></th> <th>MUL</th> <th>MUL A,</th> <th>MULW</th> <th>MULW A,</th> <th>DINO</th> <th>DIVU A,</th> <th>DIVUW</th> <th>DIVUW A,</th> <th>NI</th> <th>DIV A,</th> <th>MAIQ</th> <th>DIVW A,</th>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -             | MULU    |            | MULUW   |            | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | DIVUW   | DIVUW A,   | NI      | DIV A,   | MAIQ    | DIVW A,  |
| MULU         MULUW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | +             | A,R1    |            | A,RW1   | @RW1+d8    | A,R1    | @RW1+d8  | A,RW1   | @RW1+d8  | A,R1    | @RW1+d8    | A,RW1   | @RW1+d8    | A,R1    | @RW1+d8  | A,RW1   | @RW1+d8  |
| ARP         GRW2-468         ARW2         GRW2-468         ARRY2         GRW2-468         ARRY2           MULU         ARRY3         GRW3-468         ARRY3         GRW3-468         ARRY3           MULU         MULUW         MULUW A, M                                                                                                                                                                                                 |               | MULU    |            | MULUW   | MULUW A,   | MUL     | MUL A,   | MNLW    | MULW A,  | DIVU    | DIVU A,    | DIVUW   | DIVUW A,   | DIV     | DIV A,   | MAIG    | DIVW A,  |
| MULLU         AMULUW         MULLUW         MULLUW         MULLUW         MULL         ARB3           MULLU         A, RNV3-468         A,RNV3         GRNV3-468         A,RNV4         GRNV4-468         A,RV4           MULLU         MULLUW         MULLUW A, MULLUW A                                                                                                                                                                                                          |               | A,R2    | @RW2+d8    | A,RW2   | @RW2+d8    | A,R2    | @RW2+d8  | A RW2   | @RW2+d8  | A,R2    | @RW2+d8    | A,RW2   | @RW2+d8    | A,R2    | @RW2+d8  | A,RW2   | @RW2+d8  |
| A,R3         GFW/3-468         A,RW3         GFW/3-468         A,RW4           MULU         A,RW4         GFW/4-468         A,RW4         GFW/4-468         A,RW4           MULU         A,RB         GFW/5-468         A,RW5         GFW/5-468         A,RB           MULU         A,RB         GFW/6-468         A,RW5         GFW/6-468         A,RF           MULU         A,RB         GFW/6-468         A,RF         A,RF         A,RF           MULU         A,GRW         GFW/6-468         A,RF         A,RF         A,RF           MULU         A,GRW         GFW/6-468         A,RF         A,RF         A,RF           MULU         A,GRW         GFW/7-468         A,GRW         A,GRW         A,GRW           MULU         A,GRW         GFW/7-416         A,GRW         A,GRW         A,GRW<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               |         | MULU A,    | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | DIVUW   | DIVUW A,   | NO      | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW A, MULUW         MULUW A, MULUW         MULU         AR4           MULU         A, RW4         BRW4+68         A,RW4         BRW4+68         A,RB           MULU         A, RW6         BRW5+68         A,RW5         BRW5+68         A,RB           MULU         A, BW6         BRW6+48         A,RB         A,RB         A,RB           MULU         A, BW1         BRW7+48         A,RB         A,RB         A,RB           MULU         A, BW1         BRW7+48         A,RB         A,RB         A,RB           MULU         A, BW1         BRW7+48         A,RB         A,RB         A,RB           MULU         A, BW1         BRW1-448         A,RB         A,RB         A,RB           MULU         A, BW1         BRW1-446         A,RB         A,RB         A,RB           MULU         A, BW1         BRW1-446         A,RB         A,RB         A,RB           MULU         A, BRW2         BRW1-446         A,RB         A,RB         A,RB           MULU         A, BRW2         BRW1-446         A,RB         A,RB         A,RB           MULU         A,RB         A,RB         A,RB         A,RB         A,RB <th></th> <td>A,R3</td> <td></td> <td>A,RW3</td> <td>@RW3+d8</td> <td>A,R3</td> <td>@RW3+d8</td> <td>A RW3</td> <td>@RW3+d8</td> <td>A,R3</td> <td>@RW3+d8</td> <td>A,RW3</td> <td>@RW3+d8</td> <td>A,R3</td> <td>@RW3+d8</td> <td>A,RW3</td> <td>@RW3+d8</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |               | A,R3    |            | A,RW3   | @RW3+d8    | A,R3    | @RW3+d8  | A RW3   | @RW3+d8  | A,R3    | @RW3+d8    | A,RW3   | @RW3+d8    | A,R3    | @RW3+d8  | A,RW3   | @RW3+d8  |
| A,R4         ERW4+68         A,RW4         ERW4+68         A,RW4           MULU         A, MULUW         MULUW A, MULUW         MULUW A, MULUW           MULU         A, BRW5+68         A,RW5         BRW5+68         A,RB           MULU         A, BRW6         BRW6+68         A,RW         BRW6+68         A,RF           MULU         A, BRW7         BRW7+48         A,RF         A,RF         A,RF           MULU         MULUW         MULUWA, MULUWA                                                                                                                                                                                                                                                                                                                                                                         |               | MULU    |            | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINU    | DIVU A,    | DIVUW   | DIVUW A,   | NO      | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW A, MULUW         MULUW A, MULUW         MULUW A, MULUW         MULUW A, MULUW A                                                                     | + 4           | A,R4    | • • • • •  | A,RW4   | @RW4+d8    | A,R4    | @RW4+d8  | A RW4   | @RW4+d8  | A,R4    | @RW4+d8    | A,RW4   | @RW4+d8    | A,R4    | @RW4+d8  | A,RW4   | @RW4+d8  |
| A,RB         GRW5-468         A,RW5         GRW5-468         A,RW5           MULU         A,RB         GRW6-468         A,RW6         GRW6-468         A RB           MULU         A,RW         GRW7-468         A,RW7         GRW7-468         A,RY           MULU         MULUW         MULUW A, MULUW A, MULUW A, MULUW A, MULUW         MULUW         A,GRW0           MULU         A,GRW1         GRW0-416         A,GRW1         GRW1-448         A,GRW1           MULU         A,GRW1         GRW1-446         A,GRW1         GRW1-446         A,GRW1           MULU         A,GRW2         GRW2-416         A,GRW2         GRW1-416         A,GRW1           MULU         A,GRW3         GRW3-416         A,GRW3         GRW3-416         A,GRW2           MULU         A,GRW3         GRW3-416         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW3         GRW3-416         A,GRW3         GRW3-416         A,GRW3           A,GRW4         GRW4-41         A,GRW4         A,GRW4         A,GRW4         A,GRW4           A,GRW4         GRW4-41         A,GRW4         A,GRW4         A,GRW4         A,GRW4           A,GRW4         GRW4-41         A,GRW4         A,G                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               | MULU    |            | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,    | DIVUW   | DIVUW A,   | DIV     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW         A, MULUW           MULU         A, RW6         BRW6+48         A RW           MULU         A, MULUW         MULUW         A, MUL           MULU         A, BRW7         BRW7+48         A, BRW7           MULU         A, BRW7         BRW7+48         A, BRW7           MULU         A, BRW7         BRW7+48         A, BRW7           MULU         A, BRW1         BRW1+416         A, BRW1           MULU         A, BRW1         BRW1+416         A, BRW1           MULU         A, BRW2         BRW2+416         A, BRW2           MULU         A, BRW2         BRW2+416         A, BRW3           MULU         A, BRW3         BRW3+416         A, BRW3           MULU         A, BRW3         BRW3+416         A, BRW3           A, BRW4         BRW4+4W         BRW4+4W         A, BRW4+           A, BRW4         BRW1+RW7         A, BRW4+         A, BRW4+           A, BRW4         BRW1+RW7         A, BRW4+         A, BRW4+           A, BRW4         BRW4+4         BRW4+4         A, BRW4+           A, BRW4         BRW4+4         A, BRW4+           A, BRW4         BRW4+4         A, BRW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | A,R5    |            | A,RW5   | @RW5+d8    | A,R5    | @RW5+d8  | A RW5   | @RW5+d8  | A,R5    | @RW5+d8    | A,RW5   | @RW5+d8    | A,R5    | @RW5+d8  | A,RW5   | @RW5+d8  |
| A,RB         GRW6-468         A,RW6         GRW6-468         A,RW7           MULU         A, MULUW         MULUW A, MULUW A, MULUW A, MULUW A, MULUW         MULUW A, GRW1         A,GRW1           MULU         A,GRW1         GRW1-416         A,GRW1           MULU         A,GRW2         GRW2-416         A,GRW1           MULU         A,GRW2         GRW2-416         A,GRW2           MULU         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW4         MULUW         A,GRW3           MULU         A,GRW4         GRW4-HW7         A,GRW4           A,GRW1         GRW3-416         A,GRW3         GRW4-HW7           A,GRW4         GRW4-HW7         A,GRW4         A,GRW4           A,GRW4         GRW4-HW7         A,GRW4         A,GRW4           A,GRW4         GRW4-HW7         A,GRW4         A,GRW4           A,GRW4         GRW4-HW7         A,GRW4         A,GRW4           A,GRW4         GRW4-HW4         A,GRW4         A,GRW4           A,GRW4         A,GRW4         A,GRW4         A,GRW4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               | MULU    | : MULU A,  | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVO    | DIVU A,    | DIVUW   | DIVUW A,   | NIO     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW         A, MULUW         MULUW         MULUW         A, MULUW                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | A,R6    |            | A,RW6   | @RW6+d8    | A R6    | @RW6+d8  | A,RW6   | @RW6+d8  | A,R6    | @RW6+d8    | A,RW6   | @RW6+d8    | A,R6    | @RW6+d8  | A,RW6   | @RW6+d8  |
| ARP         GRW7+468         A,RW7         GRW7+468         A,RW7           MULU         A, GRW0         GRW0-416         A,GRW0         A,GRW0           MULU         A, GRW1         GRW1-416         A,GRW1           MULU         A,GRW1         GRW1-416         A,GRW1           MULU         A,GRW2         GRW2-416         A,GRW1           A,GRW2         GRW2-416         A,GRW2         A,GRW2           MULU         A,GRW2         GRW2-416         A,GRW3           MULU         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW3         GRW3-416         A,GRW3           A,GRW4         GRW4-441         A,GRW3         GRW3-416           A,GRW4         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW3         GRW3-416         A,GRW3           MULU         A,GRW1+RW7         A,GRW1+RW7         A,GRW1+RW7           A,GRW1+         GRW1+RW7         A,GRW1+RW7         A,GRW1+RW7           A,GRW1+         GRW1+RW7         A,GRW1+RW7         A,GRW1+RW7           A,GRW1+         GRW1-RW1-RW7         A,GRW1+RW7         A,GRW1+RW7           A,GRW2+         GPC-416         A,GRW2+         A,GR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |               | MULU    | :          | MULUW   |            | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | DIVUW   | DIVUW A,   | DIV     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, @RWU         A, @RWU         A, @RWU           A, @RWU         GRWU-d16         A, @RWU         BRWU-d16         A, @RWU           MULU         A, @RWI         MULUW         A, @RWI         A, @RWI           MULU         MULUW         MULUW         A, @RWI         A, @RWI           A, @RWI         GRWI-d16         A, @RWI         A, @RWI         A, @RWI           MULU         MULUW         MULUW         MULUW         A, @RWI           A, @RWI         GRWI-Adis         GRWI-Adis         A, @RWI           A, @RWI         MULUW         A, @RWI         A, @RWI           A, @RWI         MULUW         A, @RWI         A, @RWI           A, @RWI         GRWI-RWI         GRWI-RWI         A, @RWI           A, @RWI         MULUW         A, @RWI         A, @RWI           A, @RWI         GRWI-RWI         GRWI-RWI         A, @RWI           A, @RWI         GRWI-RWI         A, @RWI         A, @RWI           A, @RWI         GRWI         A, @RWI         A, @RWI           A, @RWI         A, @RWI         A, @RWI         A, @RWI           A, @RWI         A, @RWI         A, @RWI         A, @RWI           A, @RWI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               | A,R7    |            | A,RW7   |            | A,R7    | @RW7+d8  | A,RW7   | @RW7+d8  | A,R7    | @RW7+d8    | A,RW7   | @RW7+d8    | A,R7    | @RW7+d8  | A,RW7   | @RW7+d8  |
| A,@RWO         GRWO+d16         A,@RWO         GRWO+d16         A,@RWO           MULU         A, MULUW         MULUW         MULUW         A,@RWI           MULU         A,@RWI         GRW2+d16         A,@RWI           MULU         A,@RWI         GRW2+d16         A,@RWI           A,@RWI         GRW2+d16         A,@RWI         A,@RWI           MULU         A,@RWI         GRW2+d16         A,@RWI           A,@RWI         GRW3-d16         A,@RWI         A,@RWI           MULU         A,@RWI         GRW0-HWI         A,@RWI         A,@RWI           A,@RWI         GRW0-HWI         GRW0-HWI         A,@RWI         A,@RWI           A,@RWI         GRW1-HWI         GRW1-HWI         A,@RWI           A,@RWI         GRW1-HWI         A,@RWI         A,@RWI           A,@RWI         GRW1-HWI         A,@RWI         A,@RWI           A,@RWI         GRW1-HWI         A,@RWI         A,@RWI           A, GRW2         A,@RWI         A,@RWI         A,@RWI           A, GRW2         A,@RWI         A,@RWI         A,@RWI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | MULU    |            | MULUW   |            | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | DIVUW   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, @RW1         MULUW         MULUW <t< th=""><th></th><td>A,@RW0</td><td>@RW0+d16</td><td></td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td><td>A,@RW0</td><td>@RW0+d16</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               | A,@RW0  | @RW0+d16   |         | @RW0+d16   | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16   | A,@RW0  | @RW0+d16   | A,@RW0  | @RW0+d16 | A,@RW0  | @RW0+d16 |
| A,@RW1         @RW1+d16         A,@RW1         @RW1+d16         A,@RW1           MULU         A,@RW2         MULUW         A,@RW2         A,@RW2           MULU         MULUW         MULUW         A,@RW3         A,@RW3           MULU         MULUW         MULUW         A,@RW3         A,@RW3           MULU         MULUW         MULUW         A,@RW1+         A,@RW1+           MULU         MULUW         MULUW         A,@RW1+         A,@RW1+           MULU         MULU         A,@RW1+         BRW1+RW7         A,@RW1+           MULU         MULU         MULUW         MULUW         A,@RW2+           MULU         MULU         MULUW         MULUW         A,@RW2+           MULU         MULU         MULUW         MULUW         A,@RW2+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               | MULU    | MULU A,    |         | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | MNAId   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULLUW         MULLUW<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |               | A,@RW1  | @RW1+d16   | A,@RW1  | @RW1+d16   | A,@RW1  | @RW1+d16 | A @RW1  | @RW1+d16 | A,@RW1  | @RW1+d16   | A,@RW1  | @RW1+d16   | A,@RW1  | @RW1+d16 | A,@RW1  | @RW1+d16 |
| A,@RW2         GRW2+d16         A,@RW2         GRW2+d16         A,@RW2           MULU         A, MULU         A,@RW3         GRW3+d16         A,@RW3           MULU         MULU         A,@RW3         GRW3+d16         A,@RW3           A,@RW0         MULUW         MULUW         A,@RW3+d16         A,@RW3+d16           A,@RW0         GRW0+RW7         A,@RW0+         MULUW         A,@RW0+           MULU         MULUW         A,@RW1+         GRW1+RW7         A,@RW1+           A,@RW2+         GPC+d16         A,@RW1+         GPC+d16         A,@RW2+           MULU         MULU         A,@RW2+         A,@RW2+         A,@RW2+           A,@RW2+         GPC+d16         A,@RW2+         A,@RW2+         A,@RW2+           A,@RW2+         A,@RW2+         A,@RW2+         A,@RW2+         A,@RW2+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               | MULU    | MULU A,    | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINU    | DIVU A,    | DIVUW   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, @RW3         MULUW         A, @RW3           MULU         A, @RW3-d16         A, @RW3         BRW3-d16         A, @RW3           MULU         MULUW         MULUW A, MULUW A, MULUW A, MUL         MULUW A, MULU A, MULUW A, MULUW A, MULUW A, MULU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | <b>+</b>      | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16   | A,@RW2  | @RW2+d16 | A,@RW2  | @RW2+d16 |
| A,@RW3         @RW3+d16         A,@RW3         @RW3+d16         A,@RW3           MULU         A, MULUW         MULUW         MULUW         MULUW           MULU         A, @RW0+         @RW0+RW7         A,@RW0+           MULU         A, MULUW         MULUW         A, @RW1+           MULU         A, MULUW         MULUW         A, @RW2+           MULU         A, MULUW         A, @RW2+         A, @RW2+           MULU         MULUW         MULUW         A, @RW2+           MULU         MULUW         MULUW         A, @RW2+           MULU         MULUW         MULUW         A, @RW3+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |               | MULU    | : MULU A,  | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DNIO    | DIVU A,    | DIVUW   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A,         MULUW         MULUW         MULUW         A,@RW0+         MULUW         A,@RW0+         MULUW         A,@RW0+         MULUW         A,@RW1+         MULUW         A,@RW1+         MULUW         A,@RW1+         A,@RW2+         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |               | A,@RW3  | @RW3+d16   |         | @RW3+d16   | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16   | A,@RW3  | @RW3+d16   | A,@RW3  | @RW3+d16 | A,@RW3  | @RW3+d16 |
| A,@RW0+         @RW0+RW7         A,@RW0+         GRW0+RW7         A,@RW0+           MULU         A,         MULUW         MULUW         A,@RW1+           MULU         A,         MULUW         MULUW         A,@RW2+           MULU         A,         MULUW         A,@RW2+         A,@RW2+           MULU         MULUW         MULUW         A,@RW2+         A,@RW2+           A,         MULU         A,         MULUW         A,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |               | MULU    | : MULU A,  |         | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | MNAId   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW         A, @RW1+         MUL           A, @RW1+         @RW1+RW7         A, @RW1+         @RW1+RW7         A, @RW1+           MULU         A, MULUW         MULUW         A, @RW2+         BPC+416         A, @RW2+           MULU         MULU         A, MULUW         MULUW         A, MULU                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               | A,@RW0+ | : @RW0+RW7 | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 | A,@RW0+ | : @RW0+RW7 | A,@RW0+ | @RW0+RW7   | A,@RW0+ | @RW0+RW7 | A,@RW0+ | @RW0+RW7 |
| A,©RW1+ @RW1+RW7 A,©RW1+ @RW1+RW7 A,©RW1+  MULU MULU A, MULUW MULUW A, MUL  A,©RW2+ @PC-416 A,©RW2+  MULU MULU A, MULUW MULUW A, MUL  A, ©RW3-  A, |               | MULU    | : MULU A,  | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DINO    | DIVU A,    | DIVUW   | DIVUW A,   | ΛIQ     | DIV A,   | MAIG    | DIVW A,  |
| MULU         A, MULUW         MULUW         A, MULUW         MULUW         MULUW         A, MULUW         MULUW         A, MULUW <th></th> <td>A,@RW1+</td> <td>@RW1+RW7</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                       |               | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7   | A,@RW1+ | @RW1+RW7 | A,@RW1+ | @RW1+RW7 |
| A,@RW2+ :@PC+d16 A,@RW2+ :@PC+d16 A @RW2+  MULU MULU A, MULUW : MULUW A, MUL  A @BW2+ A @BW3+                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |               | MULU    | MULU A,    | MULUW   | MULUW A,   | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,    | MUVIO   | DIVUW A,   | ΔIO     | DIV A,   | MAIG    | DIVW A,  |
| MULU MULU A, MULUW MULUW A, MUL A ® DEWS. and H & A ® DEWS.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |               | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16    | A @RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16    | A,@RW2+ | @PC+d16  | A,@RW2+ | @PC+d16  |
| A @ BW/3+ : addr16 A @ BW/3+ ::                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |               | MULU    | : MULU A,  | MULUW   | : MULUW A, | MUL     | MUL A,   | MULW    | MULW A,  | DIVU    | DIVU A,    | DIVUW   | : DIVUW A, | NIO     | DIV A,   | MAIG    | DIVW A,  |
| addito A, @ DWO+ : addito                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <b>⊥</b><br>+ | A,@RW3+ | addr16     | A,@RW3+ | addr16     | A,@RW3+ | addr16   | A,@RW3+ | addr16   | A,@RW3+ | addr16     | A,@RW3+ | addr16     | A,@RW3+ | addr16   | A,@RW3+ | addr16   |

Table B.9-15 MOVEA RWi, ea Instruction (first byte =  $79_H$ )

|               | 00       | 10          | 20       | 30          | 40       | 50        | 09       | 20        | 80       | 06        | AO                | B0        | 8        | D0        | E0       | F0        |
|---------------|----------|-------------|----------|-------------|----------|-----------|----------|-----------|----------|-----------|-------------------|-----------|----------|-----------|----------|-----------|
| 4             | MOVEA    | : MOVEA RW0 | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ><br>+        | RW0,RW0  | ,@RW0+d8    | RW1,RW0  | ,@RW0+d8    | RW2,RW0  | ,@RW0+d8  | RW3,RW0  | @RW0+d8   | RW4,RW0  | ,@RW0+d8  | RW5,RW0           | ,@RW0+d8  | RW6,RW0  | ,@RW0+d8  | RW7,RW0  | ,@RW0+d8  |
| +             | MOVEA    | MOVEA RW0   | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| -             | RW0,RW1  | ,@RW1+d8    | RW1,RW1  | ,@RW1+d8    | RW2,RW1  | ,@RW1+d8  | RW3,RW1  | ,@RW1+d8  | RW4,RW1  | ,@RW1+d8  | RW5,RW1           | ,@RW1+d8  | RW6,RW1  | ,@RW1+d8  | RW7,RW1  | ,@RW1+d8  |
|               | MOVEA    | MOVEA RW0   | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| 7 +           | RW0,RW2  | ,@RW2+d8    | RW1,RW2  | ,@RW2+d8    | RW2,RW2  | ,@RW2+d8  | RW3,RW2  | ,@RW2+d8  | RW4,RW2  | ,@RW2+d8  | RW5,RW2           | ,@RW2+d8  | RW6,RW2  | ,@RW2+d8  | RW7,RW2  | ,@RW2+d8  |
| -             | MOVEA    |             | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    |           | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| რ<br>+        | RW0,RW3  | ,@RW3+d8    | RW1,RW3  | ,@RW3+d8    | RW2,RW3  | ,@RW3+d8  | RW3,RW3  | ,@RW3+d8  | RW4,RW3  | ,@RW3+d8  | RW5,RW3           | ,@RW3+d8  | RW6,RW3  | ,@RW3+d8  | RW7,RW3  | ,@RW3+d8  |
| -             | MOVEA    |             | MOVEA    | : MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| +             | RW0,RW4  | ,@RW4+d8    | RW1,RW4  | ,@RW4+d8    | RW2,RW4  | ,@RW4+d8  | RW3,RW4  | ,@RW4+d8  | RW4,RW4  | ,@RW4+d8  | RW5,RW4           | ,@RW4+d8  | RW6,RW4  | ,@RW4+d8  | RW7,RW4  | ,@RW4+d8  |
|               | MOVEA    |             | MOVEA    | : MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ი<br>+        | RW0,RW5  | ,@RW5+d8    | RW1,RW5  | ,@RW5+d8    | RW2,RW5  | ,@RW5+d8  | RW3,RW5  | ,@RW5+d8  | RW4,RW5  | ,@RW5+d8  | RW5,RW5           | ,@RW5+d8  | RW6,RW5  | ,@RW5+d8  | RW7,RW5  | @RW5+d8   |
| -             | MOVEA    | MOVEA RW0   | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| 9+            | RW0,RW6  | @RW6+d8     | RW1,RW6  | ,@RW6+d8    | RW2,RW6  | ,@RW6+d8  | RW3,RW6  | ,@RW6+d8  | RW4,RW6  | ,@RW6+d8  | RW5,RW6           | ,@RW6+d8  | RW6,RW6  | ,@RW6+d8  | RW7,RW6  | @RW6+d8   |
| -             | MOVEA    |             | MOVEA    | : MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| +             | RW0,RW7  | @RW7+d8     | RW1,RW7  | ,@RW7+d8    | RW2,RW7  | ,@RW7+d8  | RW3,RW7  | ,@RW7+d8  | RW4,RW7  | ,@RW7+d8  | RW5,RW7           | ,@RW7+d8  | RW6,RW7  | ,@RW7+d8  | RW7,RW7  | ,@RW7+d8  |
| -             | MOVEA    | MOVEA RW0   | MOVEA    | : MOVEA RW1 | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | 4         | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| æ<br>+        | RW0,@RW0 | ,@RW0+d16   | RW1,@RW0 | ,@RW0+d16   | RW2,@RW0 | ,@RW0+d16 | RW3,@RW0 | ,@RW0+d16 | RW4,@RW0 | ,@RW0+d16 | RW5,@RW0          | ,@RW0+d16 | RW6,@RW0 | ,@RW0+d16 | RW7,@RW0 | ,@RW0+d16 |
|               | MOVEA    | MOVEA RW0   |          | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| 6+            | RW0,@RW1 | ; ,@RW1+d16 | RW1,@RW1 | ; @RW1+d16  | RW2,@RW1 | ,@RW1+d16 | RW3,@RW1 | ,@RW1+d16 | RW4,@RW1 | ,@RW1+d16 | RW5,@RW1          | ,@RW1+d16 | RW6,@RW1 | ,@RW1+d16 | RW7,@RW1 | ,@RW1+d16 |
| -             | MOVEA    | MOVEA RW0   | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| <b>4</b><br>+ | RW0,@RW2 | ,@RW2+d16   | RW1,@RW2 | :           | RW2,@RW2 | ,@RW2+d16 | RW3,@RW2 | @RW2+d16  | RW4,@RW2 | ,@RW2+d16 | RW5,@RW2          | ,@RW2+d16 | RW6,@RW2 | ,@RW2+d16 | RW7,@RW2 | ,@RW2+d16 |
|               | MOVEA    | MOVEA RW0   | MOVEA    | MOVEA RW1   | MOVEA    | MOVEA RW2 | MOVEA    | MOVEA RW3 | MOVEA    | MOVEA RW4 | MOVEA             | MOVEA RW5 | MOVEA    | MOVEA RW6 | MOVEA    | MOVEA RW7 |
| ъ<br>+        | RW0,@RW3 | ,@RW3+d16   | _        | ,@RW3+d16   | RW2,@RW3 | ,@RW3+d16 | RW3,@RW3 | ,@RW3+d16 | RW4,@RW3 | ,@RW3+d16 | RW5,@RW3          | ,@RW3+d16 | RW6,@RW3 | ,@RW3+d16 | RW7,@RW3 | ,@RW3+d16 |
|               | MOVEA R  | MOVEA RW0   | MOVEA R  | MOVEA RW1   | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R           | MOVEA RW5 | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ပ<br>+        | W0,@RW0+ | ; ,@RW0+RW7 | W1,@RW0+ | ,@RW0+RW7   | W2,@RW0+ | ,@RW0+RW7 | W3,@RW0+ | ,@RW0+RW7 | W4,@RW0+ | ,@RW0+RW7 | W5,@RW0+          | ,@RW0+RW7 | W6,@RW0+ | ,@RW0+RW7 | W7,@RW0+ | ,@RW0+RW7 |
|               | MOVEA R  | MOVEA RW0   | MOVEA R  | MOVEA RW1   | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R           | MOVEA RW5 | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ก<br>+        | W0,@RW1+ | ;,@RW1+RW7  | W1,@RW1+ | ,@RW1+RW7   | W2,@RW1+ | ,@RW1+RW7 | W3,@RW1+ | ,@RW1+RW7 | W4,@RW1+ | ,@RW1+RW7 | W5,@RW1+          | ,@RW1+RW7 | W6,@RW1+ | ,@RW1+RW7 | W7,@RW1+ | ,@RW1+RW7 |
|               | MOVEA R  | MOVEA RW0   | MOVEA R  | MOVEA RW1   | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R           | MOVEA RW5 | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ш<br>+        | W0,@RW2+ | ,@PC+d16    | W1,@RW2+ | , @PC+d16   | W2,@RW2+ | ,@PC+d16  | W3,@RW2+ | ,@PC+d16  | W4,@RW2+ | ,@PC+d16  | ,@PC+d16 W5,@RW2+ | ,@PC+d16  | W6,@RW2+ | ,@PC+d16  | W7,@RW2+ | ,@PC+d16  |
|               | MOVEA R  | : MOVEA RW0 | MOVEA R  | : MOVEA RW1 | MOVEA R  | MOVEA RW2 | MOVEA R  | MOVEA RW3 | MOVEA R  | MOVEA RW4 | MOVEA R           | MOVEA RW5 | MOVEA R  | MOVEA RW6 | MOVEA R  | MOVEA RW7 |
| ш<br>+        | W0,@RW3+ | ,addr16     | W1,@RW3+ | addr16,     | W2,@RW3+ | ,addr16   | W3,@RW3+ | addr16,   | W4,@RW3+ | addr16,   | W5,@RW3+          | addr16,   | W6,@RW3+ | addr16,   | W7,@RW3+ | ,addr16   |

Table B.9-16 MOV Ri, ea Instruction (first byte = 7A<sub>H</sub>)

| + 0 MOV       |         |                 |               | 30       | 40      | 20       | 00      | 2           | )       | 06       | A0      | B0       | පි      | 00        | E0      | 9<br>9   |
|---------------|---------|-----------------|---------------|----------|---------|----------|---------|-------------|---------|----------|---------|----------|---------|-----------|---------|----------|
|               |         | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | : MOV R6, | MOV     | MOV R7,  |
|               | R0,R0   | @RW0+d8         | R1,R0         | @RW0+d8  | R2,R0   | @RW0+d8  | R3,R0   | @RW0+d8     | R4,R0   | @RW0+d8  | R5,R0   | @RW0+d8  | R6,R0   | @RW0+d8   | R7,R0   | @RW0+d8  |
| -<br>+        | MOV     | MOV R0,         |               | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
|               | R0,R1   | @RW1+d8         | R1,R1         | @RW1+d8  | R2,R1   | @RW1+d8  | R3,R1   | @RW1+d8     | R4,R1   | @RW1+d8  | R5,R1   | @RW1+d8  | R6,R1   | @RW1+d8   | R7,R1   | @RW1+d8  |
| NOM           |         |                 | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| 7 +           | R0,R2   | @RW2+d8         | R1,R2         | @RW2+d8  | R2,R2   | @RW2+d8  | R3,R2   | @RW2+d8     | R4,R2   | @RW2+d8  | R5,R2   | @RW2+d8  | R6,R2   | @RW2+d8   | R7,R2   | @RW2+d8  |
|               |         | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| ۶<br>+        | R0,R3   | @RW3+d8         | R1,R3         | @RW3+d8  | R2,R3   | @RW3+d8  | R3,R3   | @RW3+d8     | R4,R3   | @RW3+d8  | R5,R3   | @RW3+d8  | R6,R3   | @RW3+d8   | R7,R3   | @RW3+d8  |
| NOM           |         | MOV R0,         |               | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| <del>+</del>  | R0,R4   | @RW4+d8         | R1,R4         | @RW4+d8  | R2,R4   | @RW4+d8  | R3,R4   | @RW4+d8     | R4,R4   | @RW4+d8  | R5,R4   | @RW4+d8  | R6,R4   | @RW4+d8   | R7,R4   | @RW4+d8  |
| ı             |         | MOV R0,         | MOV           | MOV R1,  | ~       | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| c +           | R0,R5   | @RW5+d8         | R1,R5         | @RW5+d8  | R2,R5   | @RW5+d8  | R3,R5   | @RW5+d8     | R4,R5   | @RW5+d8  | R5,R5   | @RW5+d8  | R6,R5   | @RW5+d8   | R7,R5   | @RW5+d8  |
|               |         | MOV R0,         |               | MOV R1.  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| 9 +           | R0,R6   | @RW6+d8         | R1,R6         | @RW6+d8  | R2,R6   | @RW6+d8  | R3,R6   | @RW6+d8     | R4,R6   | @RW6+d8  | R5,R6   | @RW6+d8  | R6,R6   | @RW6+d8   | R7,R6   | @RW6+d8  |
|               |         | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| + 7           |         | @RW7+d8         |               | @RW7+d8  | R2,R7   | @RW7+d8  | R3,R7   | @RW7+d8     | R4,R7   | @RW7+d8  | R5,R7   | @RW7+d8  | R6,R7   | @RW7+d8   | R7,R7   | @RW7+d8  |
|               | MOV     | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| 8 +<br>B      |         | @RW0+d16        | R1,@RW0       | @RW0+d16 | R2,@RW0 | @RW0+d16 | ®RW0    |             |         | @RW0+d16 | R5,@RW0 |          | R6,@RW0 |           | R7,@RW0 | @RW0+d16 |
|               | MOV     | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| 6+            | R0,@RW1 | @RW1+d16        | R1,@RW1       | @RW1+d16 | R2,@RW1 | @RW1+d16 | R3,@RW1 | @RW1+d16    | R4,@RW1 | @RW1+d16 | R5,@RW1 | @RW1+d16 | R6,@RW1 | @RW1+d16  | R7,@RW1 | @RW1+d16 |
|               | MOV     | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| 4<br>4        | Ω       | @RW2+d16        |               | @RW2+d16 | R2,@RW2 | @RW2+d16 | @RW2    | @RW2+d16    | R4,@RW2 | @RW2+d16 | R5,@RW2 |          | R6,@RW2 | @RW2+d16  | R7,@RW2 | @RW2+d16 |
|               | MOV     | MOV R0,         | MOV           | MOV R1,  | MOV     | MOV R2,  | MOV     | MOV R3,     | MOV     | MOV R4,  | MOV     | MOV R5,  | MOV     | MOV R6,   | MOV     | MOV R7,  |
| ас<br>М<br>+  |         | @RW3+d16        |               | @RW3+d16 | R2,@RW3 | @RW3+d16 | R3,@RW3 | @RW3+d16    | R4,@RW3 | @RW3+d16 | R5,@RW3 |          | R6,@RW3 |           | R7,@RW3 | @RW3+d16 |
|               | MOV R0, | MOV R0,         | MOV R1,       | MOV R1,  | MOV R2, | MOV R2,  | MOV R3, | _           | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,   | MOV R7, | MOV R7,  |
| ပ<br>+        |         | @RW0+RW7        | @RW0+         | @RW0+RW7 | @RW0+   | @RW0+RW7 |         | @RW0+RW7    | @RW0+   | @RW0+RW7 | @RW0+   |          |         | @RW0+RW7  | @RW0+   | @RW0+RW7 |
|               | MOV R0, | MOV R0,         | MOV R1,       | MOV R1,  | MOV R2, | MOV R2,  | MOV R3, | MOV R3,     | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,   | MOV R7, | MOV R7,  |
| Ω<br>+        |         | @RW1+RW7        | @RW1+         | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7    | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7 | @RW1+   | @RW1+RW7  | @RW1+   | @RW1+RW7 |
|               | MOV R0, | MOV R0,         | MOV R1,       | MOV R1,  | MOV R2, | MOV R2,  | MOV R3, | MOV R3,     | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,   | MOV R7, | MOV R7,  |
| <b>Ш</b><br>+ | @RW2+   | @PC+d16         |               | @PC+d16  | @RW2+   | @PC+d16  | @RW2+   | @PC+d16     | @RW2+   | @PC+d16  | @RW2+   |          | @RW2+   | @PC+d16   |         | @PC+d16  |
|               | OV R0,  | MOV R0, MOV R0, | MOV R1, MOV R | MOV R1,  | MOV R2, | MOV R2,  | MOV R3, | R3, MOV R3, | MOV R4, | MOV R4,  | MOV R5, | MOV R5,  | MOV R6, | MOV R6,   | MOV R7, | MOV R7,  |
| <u>т</u><br>+ | @RW3+   | addr16          | @RW3+         | addr16   | @RW3+   | addr16   | @RW3+   | addr16      | @RW3+   | addr16   | @RW3+   | addr16   | @RW3+   | addr16    | @RW3+   | addr16   |

Table B.9-17 MOVW RWi, ea Instruction (first byte = 7B<sub>H</sub>)

|          | 00       | 10               | 20       | 30        | 40       | 90        | 09                | 02        | 80       | 06        | A0                | B0                | 00                | 0G        | E0                | F0        |
|----------|----------|------------------|----------|-----------|----------|-----------|-------------------|-----------|----------|-----------|-------------------|-------------------|-------------------|-----------|-------------------|-----------|
| -        | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5          | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| o<br>+   | RW0,RW0  | ,@RW0+d8         | RW1,RW0  | @RW0+d8   | RW2,RW0  | ,@RW0+d8  | RW3,RW0           | @RW0+d8   | RW4,RW0  | @RW0+d8   | RW5,RW0           | @RW0+d8           | RW6,RW0           | ,@RW0+d8  | RW7,RW0           | @RW0+d8   |
| -        | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5          | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| -        | RW0,RW1  | ,@RW1+d8         | RW1,RW1  | ,@RW1+d8  | RW2,RW1  | ,@RW1+d8  | RW3,RW1           | ,@RW1+d8  | RW4,RW1  | ,@RW1+d8  | RW5,RW1           | ,@RW1+d8          | RW6,RW1           | ,@RW1+d8  | RW7,RW1           | ,@RW1+d8  |
| -        | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW     | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| 7 +      | RW0,RW2  | RW0,RW2 ,@RW2+d8 | RW1,RW2  | ,@RW2+d8  | RW2,RW2  | ,@RW2+d8  | RW3,RW2           | ,@RW2+d8  | RW4,RW2  | ,@RW2+d8  | RW5,RW2           | @RW2+d8           | RW6,RW2           | ,@RW2+d8  | RW7,RW2           | @RW2+d8   |
| 4        | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  |                   |           | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW     | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
|          | RW0,RW3  | ,@RW3+d8         | RW1,RW3  | ,@RW3+d8  | RW2,RW3  | ,@RW3+d8  | RW3,RW3           | ,@RW3+d8  | RW4,RW3  | ,@RW3+d8  | RW5,RW3           | @RW3+d8           | RW6,RW3           | ,@RW3+d8  | RW7,RW3           | ,@RW3+d8  |
| +        | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              |           | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW     | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| <b>⊦</b> | RW0,RW4  | ,@RW4+d8         | RW1,RW4  | ,@RW4+d8  | RW2,RW4  | ,@RW4+d8  | RW3,RW4           | ,@RW4+d8  | RW4,RW4  | ,@RW4+d8  | RW5,RW4           | ,@RW4+d8          | RW6,RW4           | ,@ RW4+d8 | RW7,RW4           | ,@RW4+d8  |
|          | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              |           | MOVW     | MOVW RW4  | MOVW              | MOVW RW5          | _                 | MOVW RW6  | MOVW              | MOVW RW7  |
| ი<br>+   | RW0,RW5  | ,@RW5+d8         | RW1,RW5  | ,@RW5+d8  | RW2,RW5  | ,@RW5+d8  | RW3,RW5           | ,@RW5+d8  | RW4,RW5  | ,@RW5+d8  | RW5,RW5           | ,@RW5+d8          | RW6,RW5           | ,@RW5+d8  | RW7,RW5           | ,@RW5+d8  |
|          | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW     | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| 9<br>+   | RW0,RW6  | ,@RW6+d8         | RW1,RW6  | ,@RW6+d8  | RW2,RW6  | @RW6+d8   | RW3,RW6           | ,@RW6+d8  | RW4,RW6  | ,@RW6+d8  | RW5,RW6           | ,@RW6+d8          | RW6,RW6           | @RW6+d8   | RW7,RW6           | ,@RW6+d8  |
|          | MOVW     | MOVW RW0         | MOVW     | MOVW RW1  | MOVW     | MOVW RW2  | MOVW              | MOVW RW3  | MOVW     | MOVW RW4  | MOVW              | MOVW RW5 MOVW     | MOVW              | MOVW RW6  | MOVW              | MOVW RW7  |
| / +      | RW0,RW7  | ,@RW7+d8         | RW1,RW7  | ,@RW7+d8  | RW2,RW7  | ,@RW7+d8  | RW3,RW7           | ,@RW7+d8  | RW4,RW7  | ,@RW7+d8  | RW5,RW7           | ,@RW7+d8          | RW6,RW7           | ,@RW7+d8  | RW7,RW7           | ,@RW7+d8  |
|          | MOVW     | MOVW RWO,        | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW              | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,         |                   | MOVW RW6, | MOVW              | MOVW RW7, |
| ∞<br>+   | RWO,@RW0 | @RW0+d16         | RW1,@RW0 | @RW0+d16  | RW2,@RW0 | @RW0+d16  | RW3,@RW0          | @RW0+d16  | RW4,@RW0 | @RW0+d16  | RW5,@RW0          | @RW0+d16          | RW6,@RW0          | @RW0+d16  | RW7,@RW0          | @RW0+d16  |
|          | MOVW     | MOVW RWO,        | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW              | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,         | MOVW              | MOVW RW6, | MOVW              | MOVW RW7, |
| 6<br>+   | RWO,@RW1 | @RW1+d16         | RW1,@RW1 | @RW1+d16  | RW2,@RW1 | @RW1+d16  | RW3,@RW1          | @RW1+d16  | RW4,@RW1 | @RW1+d16  | RW5,@RW1          | @RW1+d16 RW6,@RW1 | RW6,@RW1          | @RW1+d16  | RW7,@RW1          | @RW1+d16  |
| -        | MOVW     | MOVW RWO,        | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW              | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5, MOVW    | MOVW              | MOVW RW6, | MOVW              | MOVW RW7, |
| ¥<br>+   | RWO,@RW2 | @RW2+d16         | RW1,@RW2 | @RW2+d16  | RW2,@RW2 | @RW2+d16  | RW3,@RW2          | @RW2+d16  | RW4,@RW2 | @RW2+d16  | RW5,@RW2          | @RW2+d16 RW6,@RW2 | RW6,@RW2          | @RW2+d16  | RW7,@RW2          | @RW2+d16  |
|          | MOVW     | MOVW RWO,        | MOVW     | MOVW RW1, | MOVW     | MOVW RW2, | MOVW              | MOVW RW3, | MOVW     | MOVW RW4, | MOVW              | MOVW RW5,         | MOVW              | MOVW RW6, | MOVW              | MOVW RW7, |
| n<br>+   | RWO,@RW3 | @RW3+d16         | RW1,@RW3 | @RW3+d16  | RW2,@RW3 | @RW3+d16  | RW3,@RW3          | @RW3+d16  | RW4,@RW3 | @RW3+d16  | RW5,@RW3          | @RW3+d16          | @RW3+d16 RW6,@RW3 | @RW3+d16  | RW7,@RW3          | @RW3+d16  |
| -        | MOVW R   | R :MOVW RWO,     | MOVW R   | MOVW RW1, | MOVW R   | MOVW RW2, | MOVW R            | MOVW RW3, | MOVW R   | MOVW RW4, | MOVW R            | MOVW RW5,         | MOVW R            | MOVW Å@R  | MOVW R            | MOVW Å@R  |
| ၁<br>+   | W0,@RW0+ | @RW0+RW7         | W1,@RW0+ | @RW0+RW7  | W2,@RW0+ | @RW0+RW7  | W3,@RW0+          | @RW0+RW7  | W4,@RW0+ | @RW0+RW7  | W5,@RW0+          | @RW0+RW7          | W6,@RW0+          | @RW0+RW7  | W7,@RW0+          | @RW0+RW7  |
|          | MOVW R   | MOVW RWO,        | MOVW R   | MOVW RW1, | MOVW R   | MOVW RW2, | MOVW R            | MOVW RW3, | MOVW R   | MOVW RW4, | MOVW R            | MOVW RW5,         | MOVW R            | MOVW RW6, | MOVW R            | MOVW RW7, |
| n<br>+   | W0,@RW1+ | @RW1+RW7         | W1,@RW1+ | @RW1+RW7  | W2,@RW1+ | @RW1+RW7  | W3,@RW1+          | @RW1+RW7  | W4,@RW1+ | @RW1+RW7  | W5,@RW1+          | @RW1+RW7 W6,@RW1+ | W6,@RW1+          | @RW1+RW7  | W7,@RW1+          | @RW1+RW7  |
|          | MOVW R   | MOVW RW0         | MOVW R   | MOVW RW1  | MOVW R   | MOVW RW2  | MOVW R            | MOVW RW3  | MOVW R   | MOVW RW4  | MOVW R            | MOVW RW5 MOVW     | MOVW R            | MOVW RW6  | MOVW R            | MOVW RW7  |
| +        |          | ,@PC+d16         |          | ,@PC+d16  | W2,@RW2+ | ,@PC+d16  | ,@PC+d16 W3,@RW2+ | ,@PC+d16  | W4,@RW2+ | ,@PC+d16  | ,@PC+d16 W5,@RW2+ | ,@PC+d16          | ,@PC+d16 W6,@RW2+ | ,@PC+d16  | ,@PC+d16 W7,@RW2+ | ,@PC+d16  |
|          | MOWW R   | MOVW RW          | MOVW R   | MOVW RW   | MOVW R   | MOVW RW   | MOVW R            | MOVW RW   | MOVW R   | MOVW RW   | MOVW R            | MOVW RW MOVW      | MOVW R            | MOVW RW   | MOVW R            | MOVW RW   |
| +        | W0,@RW3+ | 0,addr16         | W1,@RW3+ | 1,addr16  | W2,@RW3+ | 2,addr16  | W3,@RW3+          | 3,addr16  | W4,@RW3+ | 4,addr16  | W5,@RW3+          | 5,addr16          | 5,addr16 W6,@RW3+ | 6,addr16  | W7,@RW3+          | 7,addr16  |

Table B.9-18 MOV Ri, ea Instruction (first byte = 7C<sub>H</sub>)

|               | 00               | 10               | 50       | 30          | 40       | 20          | 09       | 70         | 80       | 06        | ΑO       | BO        | 00       | D0         | E0       | F0        |
|---------------|------------------|------------------|----------|-------------|----------|-------------|----------|------------|----------|-----------|----------|-----------|----------|------------|----------|-----------|
| -             | MOV              | MOV @R           | MOV      | : MOV @R    | MOV      | MOV @R      | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| o<br>+        | R0,R0            | R0,R0 : W0+d8,R0 | R0,R1    | W0+d8,R1    | R0,R2    | W0+d8,R2    | R0,R3    | W0+d8,R3   | R0,R4    | W0+d8,R4  | R0,R5    | W0+d8,R5  | R0,R6    | W0+d8,R6   | R0,R7    | W0+d8,R7  |
| •             | MOV              | MOV @R           | MOV      |             | MOV      | MOV @R      | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| -<br>+        | R1,R0            | : W1+d8,R0       | R1,R1    | : W1+d8,R1  | R1,R2    | : W1+d8,R2  | R1,R3    | W1+d8,R3   | R1,R4    | W1+d8,R4  | R1,R5    | W1+d8,R5  | R1,R6    | W1+d8,R6   | R1,R7    | W1+d8,R7  |
| -             | MOV              | MOV @R           | MOV      |             | MOV      |             | MOV      | MOV @R     | MOV      |           | MOV      |           | MOV      | MOV @R     | MOV      | MOV @R    |
| +5            | R2,R0            | R2,R0 : W2+d8,R0 | R2,R1    | : W2+d8,R1  | R2,R2    | : W2+d8,R2  | R2,R3    | W2+d8,R3   | R2,R4    | W2+d8,R4  | R2,R5    | W2+d8,R5  | R2,R6    | W2+d8,R6   | R2,R7    | W2+d8,R7  |
|               | MOV              | MOV @R           | MOV      |             | MOV      |             | MOV      | MOV @R     | MOV      | MOV @R    | MOV      |           | MOV      | MOV @R     | MOV      | MOV @R    |
| ÷<br>۲        | R3,R0 : W3+d8,R0 | W3+d8,R0         | R3,R1    | . W3+d8,R1  | R3,R2    | . W3+d8,R2  | R3,R3    | W3+d8,R3   | R3,R4    | W3+d8,R4  | R3,R5    | W3+d8,R5  | R3,R6    | W3+d8,R6   | R3,R7    | W3+d8,R7  |
| -             | MOV              | : MOV @R         | MOV      | : MOV @R    | MOV      |             | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| + 4           | R4,R0            | R4,R0 : W4+d8,R0 | R4,R1    | . W4+d8,R1  | R4,R2    | . W4+d8,R2  | R4,R3    | W4+d8,R3   | R4,R4    | W4+d8,R4  | R4,R5    | W4+d8,R5  | R4,R6    | W4+d8,R6   | R4,R7    | W4+d8,R7  |
|               | MOV              | MOV @R           | MOV      |             | MOV      | MOV @R      | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| + 2           | R5,R0            | R5,R0 : W5+d8,R0 | R5,R1    | : W5+d8,R1  | R5,R2    | : W5+d8,R2  | R5,R3    | W5+d8,R3   | R5,R4    | W5+d8,R4  | R5,R5    | W5+d8,R5  | R5,R6    | W5+d8,R6   | R5,R7    | W5+d8,R7  |
|               | MOV              | MOV @R           | MOV      | MOV @R      | MOV      | MOV @R      | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| 9+            | R6,R0            | R6,R0 : W6+d8,R0 | R6,R1    | : W6+d8,R1  | R6,R2    | : W6+d8,R2  | R6,R3    | : W6+d8,R3 | R6,R4    | W6+d8,R4  | R6,R5    | W6+d8,R5  | R6,R6    | W6+d8,R6   | R6,R7    | W6+d8,R7  |
|               | MOV              | MOV @R           |          | MOV @R      | MOV      | MOV @R      | MOV      | MOV @R     | MOV      | MOV @R    | MOV      | MOV @R    | MOV      | MOV @R     | MOV      | MOV @R    |
| + 2           | R7,R0            | R7,R0 : W7+d8,R0 | R7,R1    | W7+d8,R1    | R7,R2    | : W7+d8,R2  | R7,R3    | W7+d8,R3   | R7,R4    | W7+d8,R4  | R7,R5    | W7+d8,R5  | R7,R6    | : W7+d8,R6 | R7,R7    | W7+d8,R7  |
| -             | MOV              | MOV @RW          | MOV      | MOV @RW     | MOV      | MOV @RW     |          | MOV @RW    | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
| χ<br>+        | @RW0,R0          | 0+d16,R0         | @RW0,R1  | : 0+d16,R1  | @RW0,R2  | 0+d16,R2    | @RW0,R3  | 0+d16,R3   | @RW0,R4  | 0+d16,R4  | @RW0,R5  | 0+d16,R5  | @RW0,R6  | 0+d16,R6   | @RW0,R7  | 0+d16,R7  |
| -             | MOV              | MOV @RW          |          | MOV @RW     | MOV      | MOV @RW     | MOV      | MOV @RW    | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
| ກ<br>+        | @RW1,R0          | : 1+d16,R0       | @RW1,R1  | : 1+d16,R1  | @RW1,R2  | 1+d16,R2    | @RW1,R3  | 1+d16,R3   | @RW1,R4  | 1+d16,R4  | @RW1,R5  | 1+d16,R5  | @RW1,R6  | 1+d16,R6   | @RW1,R7  | 1+d16,R7  |
| <<br>+        | MOV              | MOV @RW          | MOV      |             | MOV      | MOV @RW     | MOV      | MOV @RW    | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
| -             | @RW2,R0          |                  | @RW2,R1  | 2+d16,R1    | @RW2,R2  | 2+d16,R2    | @RW2,R3  | 2+d16,R3   | @RW2,R4  | 2+d16,R4  | @RW2,R5  | 2+d16,R5  | @RW2,R6  | 2+d16,R6   | @RW2,R7  | 2+d16,R7  |
| α<br>+        | MOV              | MOV @RW          | MOV      |             | MOV      | MOV @RW     |          |            | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
|               | @RW3,R0          | 3+d16,R0         | @RW3,R1  | 3+d16,R1    | @RW3,R2  | 3+d16,R2    | @RW3,R3  | 3+d16,R3   | @RW3,R4  | 3+d16,R4  | @RW3,R5  | 3+d16,R5  | @RW3,R6  | 3+d16,R6   | @RW3,R7  | 3+d16,R7  |
| -             | MOV              | : MOV @RW        | MOV      |             | MOV      | : MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
| ک<br>+        | @RW0+,R0         | 0+RW7,R0         | @RW0+,R1 | 0+RW7,R1    | @RW0+,R2 | 0+RW7,R2    | @RW0+,R3 | 0+RW7,R3   | @RW0+,R4 | 0+RW7,R4  | @RW0+,R5 | 0+RW7,R5  | @RW0+,R6 | 0+RW7,R6   | @RW0+,R7 | 0+RW7,R7  |
|               | MOV              | MOV @RW          |          | MOV @RW     | MOV      | MOV @RW     | MOV      | MOV @RW    | MOV      | MOV @RW   | MOV      | MOV @RW   | MOV      | MOV @RW    | MOV      | MOV @RW   |
| ٦<br>+        | @RW1+,R0         | 1+RW7,R0         | @RW1+,R1 | 1+RW7,R1    | @RW1+,R2 | 1+RW7,R2    | @RW1+,R3 | 1+RW7,R3   | @RW1+,R4 | 1+RW7,R4  | @RW1+,R5 | 1+RW7,R5  | @RW1+,R6 | 1+RW7,R6   | @RW1+,R7 | 1+RW7,R7  |
| Ц             | MOV              | MOV P            | MOV      | MOV P       | MOV      | MOV P       | MOV      | MOV P      | MOV      | MOV P     | MOV      | MOV P     | MOV      | MOV P      | MOV      | MOV P     |
| <b>⊔</b><br>} | @RW2+,R0         | C+d16,R0         | @RW2+,R1 | C+d16,R1    | @RW2+,R2 | C+d16,R2    | @RW2+,R3 | C+d16,R3   | @RW2+,R4 | C+d16,R4  | @RW2+,R5 | C+d16,R5  | @RW2+,R6 | C+d16,R6   | @RW2+,R7 | C+d16,R7  |
| ц<br>Н        | MOV              | MOV              | MOV      | MOV         | MOV      | MOV         | MOV      | MOV        | MOV      | MOV       | MOV      | MOV       | MOV      | MOV        | MOV      | MOV       |
|               | @RW3+,R0         | : addr16,R0      | @RW3+,R1 | ; addr16,R1 | @RW3+,R2 | : addr16,R2 | @RW3+,R3 | addr16,R3  | @RW3+,R4 | addr16,R4 | @RW3+,R5 | addr16,R5 | @RW3+,R6 | addr16,R6  | @RW3+,R7 | addr16,R7 |

Table B.9-19 MOVW ea, Rwi Instruction (first byte = 7D<sub>H</sub>)

|               | 00       | 10         | 50       | 30         | 40       | 20         | 09       | 70         | 80       | 06          | Α0       | B0         | 8        | 00         | E0       | 9          |
|---------------|----------|------------|----------|------------|----------|------------|----------|------------|----------|-------------|----------|------------|----------|------------|----------|------------|
|               | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| ><br>+        | RW0,RW0  | 0+d8,RW0   | RW0,RW1  | 0+d8,RW1   | RW0,RW2  | 0+d8,RW2   | RW0,RW3  | 0+d8,RW3   | RW0,RW4  | 0+d8,RW4    | RW0,RW5  | 0+d8,RW5   | RW0,RW6  | 0+d8,RW6   | RW0,RW7  | 0+d8,RW7   |
|               | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     |            | MOVW     | MOVW @RW   | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| +             | RW1,RW0  | 1+d8,RW0   | RW1,RW1  | 1+d8,RW1   | RW1,RW2  | 1+d8,RW2   | RW1,RW3  | 1+d8,RW3   | RW1,RW4  | 1+d8,RW4    | RW1,RW5  | 1+d8,RW5   | RW1,RW6  | 1+d8,RW6   | RW1,RW7  | 1+d8,RW7   |
| c             | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | WOOM     | MOVW @RW   | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| N<br>+        | RW2,RW0  | 2+d8,RW0   | RW2,RW1  | 2+d8,RW1   | RW2,RW2  | 2+d8,RW2   | RW2,RW3  | 2+d8,RW3   | RW2,RW4  | 2+d8,RW4    | RW2,RW5  | 2+d8,RW5   | RW2,RW6  | 2+d8,RW6   | RW2,RW7  | 2+d8,RW7   |
| 4             | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| ი<br> -       | RW3,RW0  | 3+d8,RW0   | RW3,RW1  | 3+d8,RW1   | RW3,RW2  |            | RW3,RW3  | 3+d8,RW3   | RW3,RW4  | 3+d8,RW4    | RW3,RW5  | 3+d8,RW5   | RW3,RW6  | 3+d8,RW6   | RW3,RW7  | 3+d8,RW7   |
| +             | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| <del> </del>  | RW4,RW0  | 4+d8,RW0   | RW4,RW1  | 4+d8,RW1   | RW4,RW2  | 4+d8,RW2   | RW4,RW3  | 4+d8,RW3   | RW4,RW4  | 4+d8,RW4    | RW4,RW5  | 4+d8,RW5   | RW4,RW6  | 4+d8,RW6   | RW4,RW7  | 4+d8,RW7   |
| L             | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| ი<br>+        | RW5,RW0  | 5+d8,RW0   | RW5,RW1  | 5+d8,RW1   | RW5,RW2  | 5+d8,RW2   | RW5,RW3  | 5+d8,RW3   | RW5,RW4  | 5+d8,RW4    | RW5,RW5  | 5+d8,RW5   | RW5,RW6  | 5+d8,RW6   | RW5,RW7  | 5+d8,RW7   |
|               | MOVW     | MOVW @RW    | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   |
| 9             | RW6,RW0  | 6+d8,RW0   | RW6,RW1  | 6+d8,RW1   | RW6,RW2  | 6+d8,RW2   | RW6,RW3  | 6+d8,RW3   | RW6,RW4  | 6+d8,RW4    | RW6,RW5  | 6+d8,RW5   | RW6,RW6  | 6+d8,RW6   | RW6,RW7  | 6+d8,RW7   |
|               | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | MOVW @RW   | MOVW     | _          | WOVW     | : MOVW @RW  | WOVW     | MOVW @RW   | WOVW     | MOVW @RW   | WOVW     | MOVW @RW   |
| <b>/</b> +    | RW7,RW0  | 7+d8,RW0   | RW7,RW1  | 7+d8,RW1   | RW7,RW2  | 7+d8,RW2   | RW7,RW3  | 7+d8,RW3   | RW7,RW4  | 7+d8,RW4    | RW7,RW5  | 7+d8,RW5   | RW7,RW6  | 7+d8,RW6   | RW7,RW7  | 7+d8,RW7   |
|               | MOVW     | MOVW @RW0  | MOVW     | : MOVW @RW0 | MOVW     | MOVW @RW0  | MOVW     | MOVW @RW0  | MOVW     | MOVW @RW0  |
| ∞<br>+        | @RW0,RW0 | +d16,RW0   | @RW0,RW1 | +d16,RW1   | @RW0,RW2 | +d16,RW2   | @RW0,RW3 | : +d16,RW3 | @RW0,RW4 | +d16,RW4    | @RW0,RW5 | +d16,RW5   | @RW0,RW6 | +d16,RW6   | @RW0,RW7 | +d16,RW7   |
|               | MOVW     | MOVW @RW1   | MOVW     | MOVW @RW1  | MOVW     | MOVW @RW1  | MOVW     | MOVW @RW1  |
| ი<br>+        | @RW1,RW0 | +d16,RW0   |          | +d16,RW1   | @RW1,RW2 | +d16,RW2   | @RW1,RW3 | +d16,RW3   | @RW1,RW4 | +d16,RW4    | @RW1,RW5 | +d16,RW5   | @RW1,RW6 | +d16,RW6   | @RW1,RW7 | +d16,RW7   |
|               | MOVW     | MOVW @RW2  | MOVW     | : MOVW @RW2 | MOVW     | MOVW @RW2  | MOVW     | MOVW @RW2  | MOVW     | MOVW @RW2  |
| <b>4</b>      | @RW2,RW0 | +d16,RW0   | @RW2,RW1 | +d16,RW1   | @RW2,RW2 | +d16,RW2   | @RW2,RW3 | +d16,RW3   | @RW2,RW4 | +d16,RW4    | @RW2,RW5 | +d16,RW5   | @RW2,RW6 | +d16,RW6   | @RW2,RW7 | +d16,RW7   |
|               | MOVW     | MOVW @RW3  | MOVW     | MOVW @RW3  | MOVW     | MOVW @RW3  | WAOM     | MOVW @RW3  | MOVW     | : MOVW @RW3 | MOVW     | MOVW @RW3  | MOVW     | MOVW @RW3  | MOVW     | MOVW @RW3  |
| 9<br>+        |          | +d16,RW0   | @RW3,RW1 | +d16,RW1   | @RW3,RW2 | +d16,RW2   | @RW3,RW3 |            | @RW3,RW4 | +d16,RW4    | @RW3,RW5 | +d16,RW5   | @RW3,RW6 | +d16,RW6   | @RW3,RW7 | +d16,RW7   |
|               | MOVW @   | MOVW @RW0   | MOVW @   | MOVW @RW0  | MOVW @   | MOVW @RW0  | MOVW @   | MOVW @RW0  |
| ပ<br>+        |          | +RW7,RW0   | RW0+,RW1 | +RW7,RW1   | RW0+,RW2 | +RW7,RW2   | RW0+,RW3 | +RW7,RW3   | RW0+,RW4 | +RW7,RW4    | RW0+,RW5 | +RW7,RW5   | RW0+,RW6 | +RW7,RW6   | RW0+,RW7 | +RW7,RW7   |
|               | MOVW @   | MOVW @RW1   | MOVW @   | MOVW @RW1  | MOVW @   | MOVW @RW1  | MOVW @   | MOVW @RW1  |
| Ω<br>+        | RW1+,RW0 | +RW7,RW0   |          | +RW7,RW1   | RW1+,RW2 | +RW7,RW2   | RW1+,RW3 | +RW7,RW3   | RW1+,RW4 | +RW7,RW4    | RW1+,RW5 | +RW7,RW5   | RW1+,RW6 | +RW7,RW6   | RW1+,RW7 | +RW7,RW7   |
|               | MOVW @   | MOVW @PC+  | MOVW @   | MOVW @PC+  | MOVW @   | MOVW @PC+  | ® M∆OM   | MOVW @PC+  | MOVW @   | : MOVW @PC+ | MOVW @   | MOVW @PC+  | MOVW @   | MOVW @PC+  | MOVW @   | MOVW @PC+  |
| ш<br>+        | RW2+,RW0 | d16,RW0    |          | d16,RW1    | RW2+,RW2 | d16,RW2    | RW2+,RW3 | d16,RW3    | RW2+,RW4 | d16,RW4     | RW2+,RW5 | d16,RW5    | RW2+,RW6 | d16,RW6    | RW2+,RW7 | d16,RW7    |
|               | MOVW @   | MOVW        | MOVW @   | MOVW       | MOVW @   | MOVW       | MOVW @   | MOVW       |
| <u>н</u><br>+ | RW3+,RW0 | addr16,RW0 | RW3+,RW1 | addr16,RW1 | RW3+,RW2 | addr16,RW2 | RW3+,RW3 | addr16,RW3 | RW3+,RW4 | addr16,RW4  | RW3+,RW5 | addr16,RW5 | RW3+,RW6 | addr16,RW6 | RW3+,RW7 | addr16,RW7 |

Table B.9-20 XCH Ri, ea Instruction (first byte = 7E<sub>H</sub>)

| + + + 0    |          |          | Q.       | 30       | 40       | 20       | 09       | 20       | 80       | 06         | AO       | BO        | 8        | DO       | E0         | 9        |
|------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|------------|----------|-----------|----------|----------|------------|----------|
|            | хсн      | XCH R0,  | ХСН      | XCH R1,  | ХСН      | XCH R2,  | ХСН      | XCH R3,  | ХСН      | XCH R4,    | ХСН      | XCH R5,   | ХСН      | XCH R6,  | ХСН        | XCH R7,  |
|            | R0,R0    | @RW0+d8  | R1,R0    | @RW0+d8  | R2,R0    | @RW0+d8  | R3,R0    | @RW0+d8  | R4,R0    | @RW0+d8    | R5,R0    | @RW0+d8   | R6,R0    | @RW0+d8  | R7,R0      | @RW0+d8  |
|            | XCH      | XCH R0,  |          | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | NOTW R7, |
| ×          | R0,R1    | @RW1+d8  | R1,R1    | @RW1+d8  | R2,R1    | @RW1+d8  | R3,R1    | @RW1+d8  | R4,R1    | @RW1+d8    | R5,R1    | @RW1+d8   | R6,R1    | @RW1+d8  | R7,R1      | @RW1+d8  |
|            | ХСН      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
|            | R0,R2    | @RW2+d8  | R1,R2    | @RW2+d8  | R2,R2    | @RW2+d8  | R3,R2    | @RW2+d8  | R4,R2    | @RW2+d8    | R5,R2    | @RW2+d8   | R6,R2    | @RW2+d8  | R7,R2      | @RW2+d8  |
|            | ХОН      | XCH R0,  | XC.      | XCH R1,  | XCH      | XCH R2,  | XCH.     | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | X<br>E     | NOTW R7, |
| უ<br>+     | R0,R3    |          | R1,R3    | @RW3+d8  | R2,R3    | @RW3+d8  | R3,R3    | @RW3+d8  | R4,R3    | : @RW3+d8  | R5,R3    | : @RW3+d8 | R6,R3    | @RW3+d8  | R7,R3      | @RW3+d8  |
| _          | XCH      | XCH R0,  | XCH      | XCH R1,  | χCΞ      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | NOTW R7, |
| +          | R0,R4    |          | R1,R4    | @RW4+d8  | R2,R4    | @RW4+d8  | R3,R4    | @RW4+d8  | R4,R4    | @RW4+d8    | R5,R4    | @RW4+d8   | R6,R4    | @RW4+d8  | R7,R4      | @RW4+d8  |
| Ţ,         | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| ი<br>+     | R0,R5    |          | R1,R5    | @RW5+d8  | R2,R5    | @RW5+d8  | R3,R5    | @RW5+d8  | R4,R5    | @RW5+d8    | R5,R5    | @RW5+d8   | R6,R5    | @RW5+d8  | R7,R5      | @RW5+d8  |
| ,          | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| ه<br>+     | R0,R6    | @RW6+d8  |          | @RW6+d8  | R2,R6    |          | R3,R6    | @RW6+d8  | R4,R6    | @RW6+d8    | R5,R6    | @RW6+d8   | R6,R6    | @RW6+d8  | R7,R6      | @RW6+d8  |
|            | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4     | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| <u>_</u>   |          | @RW7+d8  | R1,R7    | @RW7+d8  | R2,R7    | @RW7+d8  | R3,R7    | @RW7+d8  | R4,R7    | @RW7+d8    | R5,R7    | @BW7      | R6,R7    | @RW7+d8  | R7,R7      | @RW7+d8  |
| Ι,         | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XC.        | XCH R7,  |
| <br>       | R0,@RW0  | @RW0+d16 |          |          | R2,@RW0  | @RW0+d16 |          | @RW0+d16 | R4,@RW0  | @RW0+d16   | R5,@RW0  | @RW0+d16  | R6,@RW0  | @RW0+d16 | R7,@RW0    | @RW0+d16 |
|            | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| 6<br>+     | R0,@RW1  | @RW1+d16 |          | @RW1+d16 | R2,@RW1  | @RW1+d16 | R3,@RW1  | @RW1+d16 | R4,@RW1  | @RW1+d16   | R5,@RW1  | @RW1+d16  | R6,@RW1  | @RW1+d16 | R7,@RW1    | @RW1+d16 |
| Ι.         | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| <br>K<br>+ | ,@RW2    | 6,A      |          | W2+d16,A | R2,@RW2  | W2+d16,A | ,@RW2    | W2+d16,A | R4,@RW2  | W2+d16,A   | R5,@RW2  | W2+d16,A  | R6,@RW2  | W2+d16,A | R7,@RW2    | W2+d16,A |
| ,          | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH<br>TOX | XCH R7,  |
| <br>m<br>+ | R0,@RW3  | @RW3+d16 |          |          | R2,@RW3  | @RW3+d16 | R3,@RW3  | @RW3+d16 | R4,@RW3  | : @RW3+d16 | R5,@RW3  |           | R6,@RW3  | @RW3+d16 | R7,@RW3    | ÷        |
|            | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| ပ<br>+     | R0,@RW0+ | @RW0+RW7 | R1,@RW0+ | @RW0+RW7 | R2,@RW0+ | @RW0+RW7 | R3,@RW0+ | @RW0+RW7 | R4,@RW0+ | @RW0+RW7   | R5,@RW0+ | @RW0+RW7  |          | @RW0+RW7 | R7,@RW0+   | @RW0+RW7 |
|            | XCH      | XCH R0,  | XCH      | XCH R1,  | XCH      | XCH R2,  | XCH      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| +<br>ص     | R0,@RW1+ | 7        | +        | @RW1+RW7 | R2,@RW1+ |          | R3,@RW1+ |          | R4,@RW1+ | @RW1+RW7   | R5,@RW1+ | @RW1+RW7  | R6,@RW1+ | @RW1+RW7 | R7,@RW1+   |          |
| ,          | XCH      | XCH R0,  | XOX      | XCH R1,  | XOX.     | XCH R2,  | HOX      | XCH R3,  | XCH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | XCH        | XCH R7,  |
| +<br>H     | R0,@RW2+ | @PC+d16  | R1,@RW2+ | @PC+d16  | R2,@RW2+ | @PC+d16  | R3,@RW2+ | @PC+d16  | R4,@RW2+ | @PC+d16    | R5,@RW2+ | @PC+d16   | R6,@RW2+ | @PC+d16  | R7,@RW2+   | @PC+d16  |
| Γ          | XCH      | XCH R0,  | XOX.     | XCH R1,  | XCH      | XCH R2,  | HOX      | XCH R3,  | XOH      | XCH R4,    | XCH      | XCH R5,   | XCH      | XCH R6,  | HOX        | XCH R7,  |
| +          | R0,@RW3+ | addr16   | R1,@RW3+ | addr16   | R2,@RW3+ | addr16   | R3,@RW3+ | addr16   | R4,@RW3+ | addr16     | R5,@RW3+ | addr16    | R6,@RW3+ | addr16   | R7,@RW3+   | addr16   |

Table B.9-21 XCHW RWi, ea Instruction (first byte = 7F<sub>H</sub>)

|               | 8        | 10         | 20       | 30        | 40       | 90        | 09       | 20        | 80       | 06        | A0       | B0        | 8        | 00        | 9        | 9         |
|---------------|----------|------------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|----------|-----------|
| 4             | хснм     | XCHW RW0,  | XCHW     | XCHW RW1, | хснм     | XCHW RW2, | хснм     | XCHW RW3, | хснм     | XCHW RW4, | хснм     | XCHW RW5, | хснм     | XCHW RW6, | хснм     | XCHW RW7, |
|               | RW0,RW0  | @RW0+d8    | RW1,RW0  | @RW0+d8   | RW2,RW0  | @RW0+d8   | RW3,RW0  | @RW0+d8   | RW4,RW0  | @RW0+d8   | RW5,RW0  | @RW0+d8   | RW6,RW0  | @RW0+d8   | RW7,RW0  | @RW0+d8   |
| +             | хснм     | XCHW RW0,  | XCHW     | XCHW RW1, | хснм     | XCHW RW2, | хснм     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| -             | RW0,RW1  | @RW1+d8    | RW1,RW1  | @RW1+d8   | RW2,RW1  | @RW1+d8   | RW3,RW1  | @RW1+d8   | RW4,RW1  | @RW1+d8   | RW5,RW1  | @RW1+d8   | RW6,RW1  | @RW1+d8   | RW7,RW1  | @RW1+d8   |
|               | XCHW     | XCHW RW0,  | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| ×<br>+        | RW0,RW2  | @RW2+d8    | RW1,RW2  | @RW2+d8   | RW2,RW2  | @RW2+d8   | RW3,RW2  | @RW2+d8   | RW4,RW2  | @RW2+d8   | RW5,RW2  | @RW2+d8   | RW6,RW2  | @RW2+d8   | RW7,RW2  | @RW2+d8   |
|               | XCHW     | XCHW RW0,  | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| უ<br>+        | RW0,RW3  | :@RW3+d8   | RW1,RW3  | @RW3+d8   | RW2,RW3  | @RW3+d8   | RW3,RW3  | @RW3+d8   | RW4,RW3  | @RW3+d8   | RW5,RW3  | @RW3+d8   | RW6,RW3  | @RW3+d8   | RW7,RW3  | @RW3+d8   |
| -             | хснм     | XCHW RW0,  | XCHW     | XCHW RW1, | хснм     | XCHW RW2, | XCHW     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | хснм     | XCHW RW7, |
| + 4           | RW0,RW4  | @RW4+d8    | RW1,RW4  | @RW4+d8   | RW2,RW4  | @RW4+d8   | RW3,RW4  | @RW4+d8   | RW4,RW4  | @RW4+d8   | RW5,RW4  | @RW4+d8   | RW6,RW4  | @RW4+d8   | RW7,RW4  | @RW4+d8   |
|               | хснм     | :XCHW RW0, | хснм     | XCHW RW1, | хснм     | XCHW RW2, | хснм     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | хснм     | XCHW RW6, | XCHW     | XCHW RW7, |
| 4 +           | RW0,RW5  | @RW5+d8    | RW1,RW5  | @RW5+d8   | RW2,RW5  | @RW5+d8   | RW3,RW5  | @RW5+d8   | RW4,RW5  | @RW5+d8   | RW5,RW5  | @RW5+d8   | RW6,RW5  | @RW5+d8   | RW7,RW5  | @RW5+d8   |
|               | XCHW     | XCHW RW0,  | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | хСНМ     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 9+            | RW0,RW6  | @RW6+d8    | RW1,RW6  | @RW6+d8   | RW2,RW6  | @RW6+d8   | RW3,RW6  | @RW6+d8   | RW4,RW6  | @RW6+d8   | RW5,RW6  | @RW6+d8   | RW6,RW6  | @RW6+d8   | RW7,RW6  | @RW6+d8   |
|               | XCHW     |            | XCHW     | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | хснм     | XCHW RW6, | XCHW     | XCHW RW7, |
| + 1           | RW0,RW7  | :@RW7+d8   | RW1,RW7  | @RW7+d8   | RW2,RW7  | @RW7+d8   | RW3,RW7  | @RW7+d8   | RW4,RW7  | @RW7+d8   | RW5,RW7  | :@RW7+d8  | RW6,RW7  | @RW7+d8   | RW7,RW7  | @RW7+d8   |
|               | XCHW     | XCHW RW0,  |          | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, |          | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| æ<br>+        | RW0,@RW0 | @RW0+d16   | RW1,@RW0 | @RW0+d16  | RW2,@RW0 | @RW0+d16  | RW3,@RW0 | @RW0+d16  | RW4,@RW0 | @RW0+d16  | RW5,@RW0 | @RW0+d16  | RW6,@RW0 | @RW0+d16  | RW7,@RW0 | @RW0+d16  |
|               | XCHW     | :XCHW RW0, | XCHW     | XCHW RW1, | XCHW     |           | XCHW     | XCHW RW3, | хснм     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| 6+            | RW0,@RW1 | @RW1+d16   | RW1,@RW1 | @RW1+d16  | RW2,@RW1 | @RW1+d16  | RW3,@RW1 | @RW1+d16  | RW4,@RW1 | @RW1+d16  | RW5,@RW1 | @RW1+d16  | RW6,@RW1 | @RW1+d16  | RW7,@RW1 | @RW1+d16  |
|               | XCHW     | XCHW RW0,  |          | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| <b>∀</b><br>+ | RW0,@RW2 | @RW2+d16   | RW1,@RW2 | @RW2+d16  | RW2,@RW2 | @RW2+d16  | RW3,@RW2 | @RW2+d16  | RW4,@RW2 | @RW2+d16  | RW5,@RW2 | @RW2+d16  | RW6,@RW2 | @RW2+d16  | RW7,@RW2 | @RW2+d16  |
|               | XCHW     | XCHW RW0,  |          | XCHW RW1, | XCHW     | XCHW RW2, | XCHW     | XCHW RW3, | XCHW     | XCHW RW4, | XCHW     | XCHW RW5, | XCHW     | XCHW RW6, | XCHW     | XCHW RW7, |
| я<br>+        | RW0,@RW3 | @RW3+d16   | RW1,@RW3 | @RW3+d16  | RW2,@RW3 | @RW3+d16  | RW3,@RW3 | @RW3+d16  | RW4,@RW3 | @RW3+d16  | RW5,@RW3 | @RW3+d16  | RW6,@RW3 | @RW3+d16  | RW7,@RW3 | @RW3+d16  |
|               | XCHW R   | XCHW RW0,  | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| ပ<br>+        | W0,@RW0+ | @RW0+RW7   | W1,@RW0+ | @RW0+RW7  | W2,@RW0+ | @RW0+RW7  | W3,@RW0+ | @RW0+RW7  | W4,@RW0+ | @RW0+RW7  | W5,@RW0+ | @RW0+RW7  | W6,@RW0+ | @RW0+RW7  | W7,@RW0+ | @RW0+RW7  |
|               | XCHW R   | XCHW RW0,  | XCHW R   | XCHW RW1, | XCHW R   |           | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| □<br>+        | WO,@RW1+ | @RW1+RW7   | W1,@RW1+ | @RW1+RW7  | W2,@RW1+ | @RW1+RW7  | W3,@RW1+ | @RW1+RW7  | W4,@RW1+ | @RW1+RW7  | W5,@RW1+ | @RW1+RW7  | W6,@RW1+ | @RW1+RW7  | W7,@RW1+ | @RW1+RW7  |
|               | XCHW R   | XCHW RW0,  | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| ш<br>+        | WO,@RW2+ | @PC+d16    | W1,@RW2+ | @PC+d16   | W2,@RW2+ | @PC+d16   | W3,@RW2+ | @PC+d16   | W4,@RW2+ | @PC+d16   | W5,@RW2+ | @PC+d16   | W6,@RW2+ | @PC+d16   | W7,@RW2+ | @PC+d16   |
|               | XCHW R   | XCHW RW0,  | XCHW R   | XCHW RW1, | XCHW R   | XCHW RW2, | XCHW R   | XCHW RW3, | XCHW R   | XCHW RW4, | XCHW R   | XCHW RW5, | XCHW R   | XCHW RW6, | XCHW R   | XCHW RW7, |
| њ<br>+        | WO,@RW3+ | addr16     | W1,@RW3+ | addr16    | W2,@RW3+ | addr16    | W3,@RW3+ | addr16    | W4,@RW3+ | addr16    | W5,@RW3+ | addr16    | W6,@RW3+ | addr16    | W7,@RW3+ | addr16    |

# **APPENDIX C** Timing Diagrams in Flash Memory Mode

Each timing diagram for the external pins of the Flash devices in MB90360 series during Flash Memory mode is shown below.

### ■ Data Read by Read Access



Figure C-1 Timing Diagram for Read Access

## ■ Write, Data Polling, Read (WE control)



Figure C-2 Write, Data Polling, Read (WE control)

#### Note:

- Describes the last 2-bus cycle of 4-bus cycle sequences.
- "Fx" in "FxAAAA" described as address is any of FF.

## ■ Write, Data Polling, Read (CE control)



### Figure C-3 Timing Diagram for Write Access (CE control)

#### Note

- Describes the last 2-bus cycle of 4-bus cycle sequences.
- "Fx" in "FxAAAA" described as address is any of F.

## **■** Chip Erase/sector Erase Command Sequence



Figure C-4 Timing Diagram for Write Access (chip erasing/sector erasing)

### Notes:

- SA is the sector address at erasing sector.
- The address is  $FxAAAA_H$  at erasing sector.
- "Fx" in "FxAAAA" described as address is any of F.

### **■** Data Polling

Figure C-5 Timing Diagram for Data Polling



### Note:

DQ7 is valid data (The device terminates automatic operation).

### **■** Toggle Bit

Figure C-6 Timing Diagram for Toggle Bit



### Note:

DQ6 stops toggling (The device terminates automatic operation).

## ■ RY/BY Timing during Writing/erasing

Figure C-7 Timing Diagram for Output of RY/BY Signal during Writing/erasing



### ■ RST and RY/BY Timing

Figure C-8 Timing Diagram for Output of RY/BY Signal at Hardware Reset



# **■** Enable Sector Protect/verify Sector Protect



# **■** Temporary Sector Protect Cancellation



**Figure C-10 Temporary Sector Protect Cancellation** 

# **APPENDIX D** List of Interrupt Vectors

The interrupt vector table to be referenced for interrupt processing is allocated to FFFC00<sub>H</sub> to FFFFF<sub>H</sub> in the memory area and also used for software interrupts.

## **■** List of Interrupt Vectors

Table D-1 lists the interrupt vectors for the MB90360 series.

Table D-1 Interrupt Vectors (1/2)

| Interrupt | Interment ages              | Interrupt co | ontrol register     | Vector address      | Vector address      | Vector address      | Mada variatav       |
|-----------|-----------------------------|--------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| request   | Interrupt cause             | Number       | Address             | L                   | Н                   | bank                | Mode register       |
| INT 1*    |                             |              |                     | FFFFFC <sub>H</sub> | FFFFFD <sub>H</sub> | FFFFFE <sub>H</sub> | Unused              |
| INT 2*    |                             |              |                     | FFFFF8 <sub>H</sub> | FFFFF9 <sub>H</sub> | FFFFFA <sub>H</sub> | Unused              |
| :         |                             |              |                     | :                   | :                   | :                   | :                   |
| INT 7*    |                             |              |                     | FFFFE0 <sub>H</sub> | FFFFE1 <sub>H</sub> | FFFFE2 <sub>H</sub> | Unused              |
| INT 8     | Reset                       |              |                     | FFFFDC <sub>H</sub> | FFFFDD <sub>H</sub> | FFFFDE <sub>H</sub> | FFFFDF <sub>H</sub> |
| INT 9     | INT9 instruction            |              |                     | FFFFD8 <sub>H</sub> | FFFFD9 <sub>H</sub> | FFFFDA <sub>H</sub> | Unused              |
| INT 10    | Exception                   |              |                     | FFFFD4 <sub>H</sub> | FFFFD5 <sub>H</sub> | FFFFD6 <sub>H</sub> | Unused              |
| INT 11    | Reserved                    | ICDOO        | 00000               | FFFFD0 <sub>H</sub> | FFFFD1 <sub>H</sub> | FFFFD2 <sub>H</sub> | Unused              |
| INT 12    | Reserved                    | ICR00        | 0000B0 <sub>H</sub> | FFFFCC <sub>H</sub> | FFFFCD <sub>H</sub> | FFFFCE <sub>H</sub> | Unused              |
| INT 13    | CAN1 RX                     | ICD01        | 0000B1 <sub>H</sub> | FFFFC8 <sub>H</sub> | FFFFC9 <sub>H</sub> | FFFFCA <sub>H</sub> | Unused              |
| INT 14    | CAN1 TX/NS                  | ICR01        | 0000B1H             | FFFFC4 <sub>H</sub> | FFFFC5 <sub>H</sub> | FFFFC6 <sub>H</sub> | Unused              |
| INT 15    | Reserved                    | ICDO2        | 0000002             | FFFFC0 <sub>H</sub> | FFFFC1 <sub>H</sub> | FFFFC2 <sub>H</sub> | Unused              |
| INT 16    | Reserved                    | ICR02        | 0000B2 <sub>H</sub> | FFFFBC <sub>H</sub> | FFFFBD <sub>H</sub> | FFFFBE <sub>H</sub> | Unused              |
| INT 17    | Reserved                    | ICR03        | 0000P2              | FFFFB8 <sub>H</sub> | FFFFB9 <sub>H</sub> | FFFFBA <sub>H</sub> | Unused              |
| INT 18    | Reserved                    | ICK03        | 0000B3 <sub>H</sub> | FFFFB4 <sub>H</sub> | FFFFB5 <sub>H</sub> | FFFFB6 <sub>H</sub> | Unused              |
| INT 19    | 16-bit reloadtimer2         | ICD04        | 0000B4 <sub>H</sub> | FFFFB0 <sub>H</sub> | FFFFB1 <sub>H</sub> | FFFFB2 <sub>H</sub> | Unused              |
| INT 20    | 16-bit reloadtimer3         | ICR04        | 0000D4H             | FFFFAC <sub>H</sub> | FFFFAD <sub>H</sub> | FFFFAE <sub>H</sub> | Unused              |
| INT 21    | Reserved                    | ICDOS        | 0000B5 <sub>H</sub> | FFFFA8 <sub>H</sub> | FFFFA9 <sub>H</sub> | FFFFAA <sub>H</sub> | Unused              |
| INT 22    | Reserved                    | ICR05        | оооовэн             | FFFFA4 <sub>H</sub> | FFFFA5 <sub>H</sub> | FFFFA6 <sub>H</sub> | Unused              |
| INT 23    | PPG C/D                     | ICDOC        | 00000               | FFFFA0 <sub>H</sub> | FFFFA1 <sub>H</sub> | FFFFA2 <sub>H</sub> | Unused              |
| INT 24    | PPG E/F                     | ICR06        | 0000B6 <sub>H</sub> | FFFF9C <sub>H</sub> | FFFF9D <sub>H</sub> | FFFF9E <sub>H</sub> | Unused              |
| INT 25    | Time base timer             | ICD07        | 0000P7              | FFFF98 <sub>H</sub> | FFFF99 <sub>H</sub> | FFFF9A <sub>H</sub> | Unused              |
| INT 26    | External interrupt 8 to 11  | ICR07        | 0000B7 <sub>H</sub> | FFFF94 <sub>H</sub> | FFFF95 <sub>H</sub> | FFFF96 <sub>H</sub> | Unused              |
| INT 27    | Watch Timer                 | ICD09        | 00000               | FFFF90 <sub>H</sub> | FFFF91 <sub>H</sub> | FFFF92 <sub>H</sub> | Unused              |
| INT 28    | External interrupt 12 to 15 | ICR08        | 0000B8 <sub>H</sub> | FFFF8C <sub>H</sub> | FFFF8D <sub>H</sub> | FFFF8E <sub>H</sub> | Unused              |
| INT 29    | A/D Converter               | ICDOC        | 000000              | FFFF88 <sub>H</sub> | FFFF89 <sub>H</sub> | FFFF8A <sub>H</sub> | Unused              |
| INT 30    | I/O Timer 0                 | ICR09        | 0000B9 <sub>H</sub> | FFFF84 <sub>H</sub> | FFFF85 <sub>H</sub> | FFFF86 <sub>H</sub> | Unused              |

Table D-1 Interrupt Vectors (2/2)

| Interrupt | Interrupt cause          | Interrupt co | ontrol register     | Vector address      | Vector address      | Vector address      | Mode register |
|-----------|--------------------------|--------------|---------------------|---------------------|---------------------|---------------------|---------------|
| request   | interrupt cause          | Number       | Address             | L                   | Н                   | bank                | Wode register |
| INT 31    | Reserved                 | ICR10        | 0000BA <sub>H</sub> | FFFF80 <sub>H</sub> | FFFF81 <sub>H</sub> | FFFF82 <sub>H</sub> | Unused        |
| INT 32    | Reserved                 | ICK10        | оооован             | FFFF7C <sub>H</sub> | FFFF7D <sub>H</sub> | FFFF7E <sub>H</sub> | Unused        |
| INT 33    | Input capture 0 to 3     | ICR11        | 0000BB <sub>H</sub> | FFFF78 <sub>H</sub> | FFFF79 <sub>H</sub> | FFFF7A <sub>H</sub> | Unused        |
| INT 34    | Reserved                 | ICKII        | ООООВВН             | FFFF74 <sub>H</sub> | FFFF75 <sub>H</sub> | FFFF76 <sub>H</sub> | Unused        |
| INT 35    | UART 0 RX                | ICR12        | 0000BC <sub>H</sub> | FFFF70 <sub>H</sub> | FFFF71 <sub>H</sub> | FFFF72 <sub>H</sub> | Unused        |
| INT 36    | UART 0 TX                | ICK12        | оооовсн             | FFFF6C <sub>H</sub> | FFFF6D <sub>H</sub> | FFFF6E <sub>H</sub> | Unused        |
| INT 37    | UART 1 RX                | ICR13        | 0000BD <sub>H</sub> | FFFF68 <sub>H</sub> | FFFF69 <sub>H</sub> | FFFF6A <sub>H</sub> | Unused        |
| INT 38    | UART 1 TX                | ICKIS        | оооовън             | FFFF64 <sub>H</sub> | FFFF65 <sub>H</sub> | FFFF66 <sub>H</sub> | Unused        |
| INT 39    | Reserved                 | ICR14        | 0000BE <sub>H</sub> | FFFF60 <sub>H</sub> | FFFF61 <sub>H</sub> | FFFF62 <sub>H</sub> | Unused        |
| INT 40    | Reserved                 | ICK14        | OOOOBLH             | FFFF5C <sub>H</sub> | FFFF5D <sub>H</sub> | FFFF5E <sub>H</sub> | Unused        |
| INT 41    | Flash Memory             | ICR15        | 0000BF <sub>H</sub> | FFFF58 <sub>H</sub> | FFFF59 <sub>H</sub> | FFFF5A <sub>H</sub> | Unused        |
| INT 42    | Delayed interrupt module | ICKIS        | оооовгн             | FFFF54 <sub>H</sub> | FFFF55 <sub>H</sub> | FFFF56 <sub>H</sub> | Unused        |
| INT 43    |                          |              |                     | FFFF50 <sub>H</sub> | FFFF51 <sub>H</sub> | FFFF52 <sub>H</sub> | Unused        |
| :         |                          |              |                     | :                   | :                   | :                   | :             |
| INT 254   |                          |              |                     | FFFC04 <sub>H</sub> | FFFC05 <sub>H</sub> | FFFC06 <sub>H</sub> | Unused        |
| INT 255   |                          |              |                     | FFFC00 <sub>H</sub> | FFFC01 <sub>H</sub> | FFFC02 <sub>H</sub> | Unused        |

<sup>\*:</sup> When PCB is  $FF_H$ , the vector area for the CALLV instruction is the same as that for INT #vct8 (#0 to #7). Care must be taken when using the vector for the CALLV instruction.

## ■ Interrupt Causes, Interrupt Vectors, and Interrupt Control Registers

Table D-2 summarizes the relationships among the interrupt causes, interrupt vectors, and interrupt control registers of the MB90360 series.

Table D-2 Interrupt Causes, Interrupt Vectors, and Interrupt Control Registers (1/2)

| Interrupt acuse             | F1200 1                  | DMA               | Interrupt vector    | Interrupt | control register    |
|-----------------------------|--------------------------|-------------------|---------------------|-----------|---------------------|
| Interrupt cause             | El <sup>2</sup> OS clear | channel<br>number | Number              | ICR       | Address             |
| Reset                       | N                        | #08               | FFFFDC <sub>H</sub> | -         | -                   |
| INT9 instruction            | N                        | #09               | FFFFD8 <sub>H</sub> | -         | -                   |
| Exception                   | N                        | #10               | FFFFD4 <sub>H</sub> | -         | -                   |
| Reserved                    | N                        | #11               | FFFFD0 <sub>H</sub> | ICDOO     | 0000B0 <sub>H</sub> |
| Reserved                    | N                        | #12               | FFFFCC <sub>H</sub> | ICR00     | ООООВОН             |
| CAN 1 RX                    | N                        | #13               | FFFFC8 <sub>H</sub> | ICD01     | 0000B1 <sub>H</sub> |
| CAN 1 TX/NS                 | N                        | #14               | FFFFC4 <sub>H</sub> | ICR01     | 0000В1Н             |
| Reserved                    | N                        | #15               | FFFFC0 <sub>H</sub> | ICDO2     | 0000P2              |
| Reserved                    | N                        | #16               | FFFFBC <sub>H</sub> | ICR02     | 0000B2 <sub>H</sub> |
| Reserved                    | N                        | #17               | FFFFB8 <sub>H</sub> | ICDO2     | 0000P3              |
| Reserved                    | N                        | #18               | FFFFB4 <sub>H</sub> | ICR03     | 0000B3 <sub>H</sub> |
| 16-bit reload timer 2       | Y1                       | #19               | FFFFB0 <sub>H</sub> | ICD04     | 0000P.4             |
| 16-bit reload timer 3       | Y1                       | #20               | FFFFAC <sub>H</sub> | ICR04     | 0000B4 <sub>H</sub> |
| Reserved                    | N                        | #21               | FFFFA8 <sub>H</sub> | ICD05     | 0000P5              |
| Reserved                    | N                        | #22               | FFFFA4 <sub>H</sub> | ICR05     | 0000B5 <sub>H</sub> |
| PPG C/D                     | N                        | #23               | FFFFA0 <sub>H</sub> | ICDOC     | 0000D6              |
| PPG E/F                     | N                        | #24               | FFFF9C <sub>H</sub> | ICR06     | 0000B6 <sub>H</sub> |
| Time base timer             | N                        | #25               | FFFF98 <sub>H</sub> | ICD07     | 0000B7 <sub>H</sub> |
| External interrupt 8 to 11  | Y1                       | #26               | FFFF94 <sub>H</sub> | ICR07     | 0000B/H             |
| Watch timer                 | N                        | #27               | FFFF90 <sub>H</sub> | ICDOS     | 000000              |
| External interrupt 12 to 15 | Y1                       | #28               | FFFF8C <sub>H</sub> | ICR08     | 0000B8 <sub>H</sub> |
| A/D converter               | Y1                       | #29               | FFFF88 <sub>H</sub> | ICR09     | 0000B9 <sub>H</sub> |
| I/O timer 0                 | N                        | #30               | FFFF84 <sub>H</sub> | 1CKU9     | Нефолог             |
| Reserved                    | N                        | #31               | FFFF80 <sub>H</sub> | ICD10     | 0000BA <sub>H</sub> |
| Reserved                    | N                        | #32               | FFFF7C <sub>H</sub> | ICR10     | оооодан             |
| Input capture 0 to 3        | Y1                       | #33               | FFFF78 <sub>H</sub> | ICD 11    | 0000BB <sub>H</sub> |
| Reserved                    | N                        | #34               | FFFF74 <sub>H</sub> | ICR11     | ИОООВВН             |
| UART 0 RX                   | Y2                       | #35               | FFFF70 <sub>H</sub> | ICD 12    | 0000PC              |
| UART 0 TX                   | Y1                       | #36               | FFFF6C <sub>H</sub> | ICR12     | 0000BC <sub>H</sub> |
|                             |                          |                   |                     |           |                     |

Table D-2 Interrupt Causes, Interrupt Vectors, and Interrupt Control Registers (2/2)

| Interrupt course                    | FI200 -1                 | DMA<br>channel | Interrupt vector    | Interrupt co | ontrol register     |
|-------------------------------------|--------------------------|----------------|---------------------|--------------|---------------------|
| Interrupt cause                     | El <sup>2</sup> OS clear | number         | Number              | ICR          | Address             |
| UART 1 RX                           | Y2                       | #37            | FFFF68 <sub>H</sub> | ICR13        | 0000BD <sub>H</sub> |
| UART 1 TX                           | Y1                       | #38            | FFFF64 <sub>H</sub> | ICK15        | оооовьн             |
| Reserved                            | N                        | #39            | FFFF60 <sub>H</sub> | ICR14        | 0000BE <sub>H</sub> |
| Reserved                            | N                        | #40            | FFFF5C <sub>H</sub> | ICK14        | OOOOBLH             |
| Flash memory                        | N                        | #41            | FFFF58 <sub>H</sub> | ICR15        | 0000BF <sub>H</sub> |
| Delayed interrupt generation module | N                        | #42            | FFFF54 <sub>H</sub> | ICKIS        | оооовгн             |

Y1: An EI<sup>2</sup>OS interrupt clear signal or EI<sup>2</sup>OS register read access clears the interrupt request flag.

#### Note:

For a peripheral module having two interrupt causes for one interrupt number, an EI<sup>2</sup>OS interrupt clear signal clears both interrupt request flags.

When EI<sup>2</sup>OS ends, an EI<sup>2</sup>OS clear signal is sent to every interrupt flag assigned to each interrupt number.

 $EI^2OS$  is activated when one of two interrupts assigned to an interrupt control register (ICR) is caused while  $EI^2OS$  is enabled. This means that an  $EI^2OS$  descriptor that should essentially be specific to each interrupt cause is shared by two interrupts. Therefore, while one interrupt is enabled, the other interrupt must be disabled.

Y2: An EI<sup>2</sup>OS interrupt clear signal or EI<sup>2</sup>OS register read access clears the interrupt request flag. A stop request is issued.

N: An EI<sup>2</sup>OS interrupt clear signal does not clear the interrupt request flag.

The index follows on the next page.

This is listed in alphabetic order.

# Index

| numerics                                                                        | 24-bit Operand                                               |
|---------------------------------------------------------------------------------|--------------------------------------------------------------|
| 6-bit Free-run Timer                                                            | 24-bit Operand Specification                                 |
| Block Diagram of 16-bit Free-run Timer213                                       | 512K-bit Flash Memory                                        |
| Explanation of Operation of 16-bit Free-run Timer                               | 512K-bit Flash Memory Features 530                           |
| 229                                                                             | Sector Configuration of the 512K-bit Flash Memory            |
| 6-bit I/O Timer                                                                 | 531                                                          |
| 16-bit I/O Timer Interrupt and EI <sup>2</sup> OS228                            | 8+8-bit PPG                                                  |
| Block Diagram of 16-bit I/O Timer211                                            | Setting for 8+8-bit PPG Output Operation Mode                |
| Functions of 16-bit I/O Timer210                                                | 307                                                          |
| Generation of Interrupt Request from 16-bit I/O Timer                           | 8-/10-bit A/D Converter                                      |
| 216                                                                             | 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS 358 |
| Interrupts of 16-bit I/O Timer227                                               | A/D-converted Data Protection Function in                    |
| Module Configuration of 16-bit I/O Timer210                                     | 8-/10-bit A/D Converter                                      |
| Pins of 16-bit I/O Timer216                                                     | Block Diagram of 8-/10-bit A/D Converter 341                 |
| Precautions when Using 16-bit I/O Timer233                                      | Conversion Modes of 8-/10-bit A/D Converter                  |
| Program Example of 16-bit I/O Timer234                                          |                                                              |
| 6-bit PPG Output Operation Mode                                                 | EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter 358   |
| Setting for 16-bit PPG Output Operation Mode                                    | Function of 8-/10-bit A/D Converter340                       |
| 304                                                                             | Generation of Interrupt from 8-/10-bit A/D Converter         |
| 6-bit Reload Registers                                                          | List of Registers and Reset Values of 8-/10-bit              |
| 16-bit Reload Registers (TMRLR)250                                              | A/D Converter                                                |
| 6-bit Reload Timer                                                              | Pins of 8-/10-bit A/D Converter                              |
| 16-bit Reload Timer Registers and Reset Value                                   | Precautions when Using 8-/10-bit A/D Converter               |
| 243                                                                             |                                                              |
| Block Diagram of 16-bit Reload Timer240                                         | 8-/16-bit PPG Timer                                          |
| Correspondence between 16-bit Reload Timer                                      | Block Diagram of 8-/16-bit PPG Timer C 286                   |
| Interrupt and EI <sup>2</sup> OS251                                             | Block Diagram of 8-/16-bit PPG Timer D 288                   |
| EI <sup>2</sup> OS Function of 16-bit Reload Timer251                           | Functions of 8-/16-bit PPG Timer                             |
| Generation of Interrupt Request from 16-bit                                     | Generation of Interrupt Request from 8-/16-bit               |
| Reload Timer                                                                    | PPG Timer                                                    |
| Interrupts of 16-bit Reload Timer                                               | Interrupt of 8-/16-bit PPG Timer299                          |
| Operation Modes of 16-bit Reload Timer238                                       | List of Registers and Reset Values of 8-/16-bit              |
| Pins of 16-bit Reload Timer                                                     | PPG Timer291                                                 |
| Precautions when Using 16-bit Reload Timer262 Setting of 16-bit Reload Timer252 | Operation Modes of 8-/16-bit PPG Timer 283                   |
|                                                                                 | Operation of 8-/16-bit PPG Timer300                          |
| 6-bit Timer Register                                                            | Pins of 8-/16-bit PPG Timer290                               |
| 16-bit Timer Registers (TMR)249 Operating State of 16-bit Timer Register253     | Precautions when Using 8-/16-bit PPG Timer 310               |
| Operation as 16-bit Timer Register Underflows                                   | 8-bit PPG Output 2-channel Independent Operation             |
| 255, 260                                                                        | Mode                                                         |
| 200, 200                                                                        | Setting for 8-bit PPG Output 2-channel                       |
|                                                                                 | Independent Operation Mode                                   |

| A                                                                        | Address Detection Control Register 1 (PACSR1)                             |
|--------------------------------------------------------------------------|---------------------------------------------------------------------------|
| A                                                                        | 511                                                                       |
| Accumulator (A)40                                                        | Address Match Detection                                                   |
| A/D Control Status Register                                              | Block Diagram of Address Match Detection Function                         |
| A/D Control Status Register (High) (ADCS1) 346                           | 507                                                                       |
| A/D Control Status Register (Low) (ADCS0) 349                            | List of Registers and Reset Values of Address Match Detection Function508 |
| A/D Converter                                                            | Operation of Address Match Detection Function                             |
| 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS 358             | 516                                                                       |
| A/D-converted Data Protection Function in                                | Operation of Address Match Detection Function at                          |
| 8-/10-bit A/D Converter367                                               | Storing Patch Program in E <sup>2</sup> PROM520                           |
| Block Diagram of 8-/10-bit A/D Converter341                              | Overview of Address Match Detection Function                              |
| Conversion Modes of 8-/10-bit A/D Converter                              | 506                                                                       |
| 340                                                                      | Program Example for Address Match Detection                               |
| EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter358                | Function                                                                  |
| Function of 8-/10-bit A/D Converter340                                   | Addressing                                                                |
| Generation of Interrupt from 8-/10-bit A/D Converter                     | Addressing578                                                             |
| 345                                                                      | ADER                                                                      |
| Interrupt of A/D Converter358                                            |                                                                           |
| List of Registers and Reset Values of 8-/10-bit                          | Analog Input Enable Register (ADER5,ADER 6)356                            |
| A/D Converter345                                                         | Analog Input Enable Registers (ADER)175                                   |
| Pins of 8-/10-bit A/D Converter344                                       |                                                                           |
| Precautions when Using 8-/10-bit A/D Converter                           | ADSR                                                                      |
| 369                                                                      | A/D Setting Register (ADSR0/ADSR1)352                                     |
| A/D Data Register                                                        | Alternative Mode                                                          |
| A/D Data Register (ADCR0/ADCR1)351                                       | Alternative Mode533                                                       |
| A/D Setting Register                                                     | Analog Input Enable Register                                              |
| A/D Setting Register (ADSR0/ADSR1)352                                    | Analog Input Enable Register (ADER5,ADER 6)                               |
| A/D-converted Data Protection                                            | 356                                                                       |
| A/D-converted Data Protection Function                                   | Analog Input Enable Registers (ADER)175                                   |
| in 8-/10-bit A/D Converter367                                            | Asynchronous LIN Mode                                                     |
| Abstract                                                                 | Operation in Asynchronous LIN Mode                                        |
| Abstract 551                                                             | (operation mode 3)429                                                     |
| Acceptance Filter                                                        | Asynchronous Mode                                                         |
| Acceptance Filtering490                                                  | Operation in Asynchronous Mode422                                         |
| Setting Acceptance Filter                                                |                                                                           |
| Accessing                                                                | В                                                                         |
| Accessing Multi-byte Data36                                              | Bank Addressing                                                           |
| Accumulator                                                              | Bank Addressing Types34                                                   |
| Accumulator (A)40                                                        | Bank Select Prefix                                                        |
| ADCR                                                                     | Bank Select Prefix48                                                      |
| A/D Data Register (ADCR0/ADCR1)351                                       |                                                                           |
|                                                                          | BAP                                                                       |
| ADCS                                                                     | Buffer Address Pointer (BAP)77                                            |
| A/D Control Status Register (High) (ADCS1) 346                           | Basic Configuration                                                       |
| A/D Control Status Register (Low) (ADCS0) 349 Continuous Conversion Mode | Basic Configuration of Serial Programming                                 |
|                                                                          | Connection with MB90F362/T(S),                                            |
| (ADCS:MD1,MD0= "10 <sub>B</sub> ")359                                    | MB90F367/T(S)554                                                          |
| Pause-conversion Mode (ADCS:MD1,MD0= "11 <sub>B</sub> " )                | Baud Rate                                                                 |
| Single-shot Conversion Mode                                              | Calculating the Baud Rate415                                              |
| (ADCS:MD1,MD0= $"00_B"$ or $"01_B"$ )                                    | LIN-UART Baud Rate Selection413                                           |
| 359                                                                      | Baud Rate Generator Register                                              |
| Address Detection Control Register                                       | Baud Rate Generator Register (BGRn0/n1)405                                |
| Address Detection Control Register 0 (PACSR0)                            | BGR                                                                       |
| Address Detection Control Register (FACSRO) 509                          | Baud Rate Generator Register (BGRn0/n1)405                                |

| Bidirectional Communication                        | С                                                 |      |
|----------------------------------------------------|---------------------------------------------------|------|
| Bidirectional Communication Function433            | CAN Controller                                    |      |
| Bit Timing                                         | Block Diagram of CAN Controller                   | 445  |
| Setting Bit Timing494                              | Canceling Transmission Request from CAN           | 770  |
| Block Diagram                                      | Controller                                        | 488  |
| Block Diagram of 16-bit Free-run Timer213          | Features of CAN Controller                        |      |
| Block Diagram of 16-bit I/O Timer211               | Reception Flowchart of the CAN Controller         |      |
| Block Diagram of 16-bit Reload Timer240            | Starting Transmission of CAN Controller           |      |
| Block Diagram of 8-/10-bit A/D Converter341        | Transmission Flowchart of CAN Controller          |      |
| Block Diagram of 8-/16-bit PPG Timer C286          | CAN Direct                                        |      |
| Block Diagram of 8-/16-bit PPG Timer D288          | Setting of CAN Direct Mode                        | 504  |
| Block Diagram of Address Match Detection Function  |                                                   | 507  |
| 507                                                | CAN Direct Mode Register                          |      |
| Block Diagram of CAN Controller445                 | CAN Direct Mode Register (CDMR)                   | E02  |
| Block Diagram of Clock Supervisor111               | (Only MB90V340)                                   | 502  |
| Block Diagram of Delayed Interrupt Generation      | CCR                                               | 40   |
| Module85                                           | Condition Code Register (CCR)                     | 42   |
| Block Diagram of DTP/External Interrupt315         | CDMR                                              |      |
| Block Diagram of Evaluation Chip9                  | CAN Direct Mode Register (CDMR)                   |      |
| Block Diagram of Flash/Mask ROM Version11          | (Only MB90V340)                                   | 502  |
| Block Diagram of Input Capture214                  | CE Control                                        |      |
| Block Diagram of LIN-UART387                       | Write,data Polling,read (CE control)              | 638  |
| Block Diagram of LIN-UART Pins391                  | Chip Erase                                        |      |
| Block Diagram of Low Voltage/CPU Operating         | Chip Erase/sector Erase Command Sequence          | 639  |
| Detection Reset Circuit374                         | CKSCR                                             |      |
| Block Diagram of Pull-up Control Register (PUCR)   | Configuration of the Clock Selection Register     |      |
| 174                                                | (CKSCR)                                           | 98   |
| Block Diagram of ROM Mirroring Function Select     | Clock Frequency                                   |      |
| Module526                                          | Oscillating Clock Frequency and Serial Clock Inp  | out  |
| Block Diagram of the Clock Generation Block95      | Frequency                                         |      |
| Block Diagram of the Entire Flash Memory531        | Clock Generation Block                            |      |
| Block Diagram of the External Reset Pin125         | Block Diagram of the Clock Generation Block       | 95   |
| Block Diagram of the Low-Power Consumption         | Clock Mode                                        | 00   |
| Control Circuit                                    | Clock Mode                                        | 103  |
| Block Diagram of Timebase Timer                    | Clock Mode Switching                              |      |
| Block Diagram of Watch Timer                       | Clock Mode Transition                             |      |
| Block Diagram of Watchdog Timer199                 | Internal Clock Mode                               |      |
| Buffer Address Pointer                             | Operation in Internal Clock Mode                  |      |
| Buffer Address Pointer (BAP)77                     | Program Example in Internal Clock Mode            |      |
| Bus Mode                                           | Setting of Internal Clock Mode                    |      |
| Memory Space in Each Bus Mode165                   | Sub-clock Mode                                    |      |
| Bus Operation Stop                                 | Sub-clock Mode Transition Operating When          |      |
| Conditions for Canceling Bus Operation Stop        | Sub-clock Has Already Stopped                     | 116  |
| (HALT=0)457                                        | Clock Selection Register                          |      |
| Conditions for Setting Bus Operation Stop (HALT=1) | Clock Selection Register and List of Reset Value  |      |
| 457                                                |                                                   | . 97 |
| State during Bus Operation Stop (HALT=1) 457       | Clock Supervisor                                  |      |
| BVAL                                               | Block Diagram of Clock Supervisor                 | 111  |
| Caution for Disabling Message Buffers By BVAL Bits | Overview of Clock Supervisor                      |      |
| 503                                                | Prohibition Setting of CR Oscillation Circuit and | 110  |
| BY Timing                                          | Clock Supervisor                                  | 115  |
| RST and RY/BY Timing641                            | Reoperating Setting of CR Oscillation Circuit and |      |
| RY/BY Timing during Writing/erasing641             | Clock Supervisor                                  |      |
|                                                    | Reset Check by Clock Supervisor                   |      |
|                                                    |                                                   |      |

| Clock Supervisor Control Register                             | Single-shot Conversion Mode                        |
|---------------------------------------------------------------|----------------------------------------------------|
| Clock Supervisor Control Register (CSVCR) 113                 | $(ADCS:MD1,MD0 = "00_B" \text{ or } "01_B")$       |
| Clock Supply                                                  | 359                                                |
| Cycle of Clock Supply269                                      | Counting Example                                   |
| Clocks                                                        | Counting Example417                                |
| Clocks                                                        | CPU                                                |
|                                                               | Outline of CPU Memory Space29                      |
| CMR                                                           | Outline of the CPU28                               |
| Common Register Bank Prefix (CMR)49                           | CPU Intermittent Operating Mode                    |
|                                                               | CPU Intermittent Operating Mode135                 |
| Command Sequence Chip Erase/sector Erase Command Sequence 639 | CPU Intermittent Operation Mode                    |
| Command Sequence Table                                        | CPU Intermittent Operation Mode142                 |
| Common Register Bank Prefix                                   | CPU Operating Detection Reset Circuit              |
| Common Register Bank Prefix (CMR)49                           | Block Diagram of Low Voltage/CPU Operating         |
|                                                               | Detection Reset Circuit374                         |
| Communication Bidirectional Communication Function            | CPU Operating Detection Reset Circuit              |
| LIN-master-slave Communication Function 438                   | Notes on Using CPU Operating Detection Reset       |
| Master-slave Communication Function                           | Circuit379                                         |
|                                                               | Operating of CPU Operating Detection Reset Circuit |
| Comparing Time                                                | 378                                                |
| Setting of Comparing Time (CT2 to CT0 bits)355                | Operating of Low Voltage/CPU Operating Detection   |
|                                                               | Reset Circuit378                                   |
| Condition Code Register  Condition Code Register (CCR)        | Sample Program for Low Voltage/CPU Operating       |
| Condition Code Register (CCR)                                 | Detection Reset Circuit380                         |
| Configuration of the Clock Selection Register                 | CPU Operating Modes                                |
| Configuration of the Clock Selection Register                 | CPU Operating Modes and Current Consumption        |
| (CKSCR)                                                       | 134                                                |
| Configuration of the PLL/Subclock Control Register            | CR Oscillation Circuit                             |
| Configuration of the PLL/Subclock Control Register            | Prohibition Setting of CR Oscillation Circuit and  |
| (PSCCR)101                                                    | Clock Supervisor115                                |
| Continuous Conversion Mode                                    | Reoperating Setting of CR Oscillation Circuit and  |
| Continuous Conversion Mode                                    | Clock Supervisor115                                |
| (ADCS: MD1,MD0= "10 <sub>B</sub> ")                           | CSR                                                |
| Operation of Continuous Conversion Mode                       | Control Status Register (CSR) (Lower)453           |
|                                                               | Control Status Register (CSR) (upper)453           |
| Control Status Register                                       | Control Status Register (CSR-lower)454             |
| Control Status Register (CSR) (Lower)                         | CSVCR                                              |
| Control Status Register (CSR-lower)                           | Clock Supervisor Control Register (CSVCR)113       |
|                                                               | СТ                                                 |
| Conversion Using EI <sup>2</sup> OS                           | Setting of Comparing Time (CT2 to CT0 bits)355     |
| ——————————————————————————————————————                        | Current Consumption                                |
| Conversion Mode                                               | CPU Operating Modes and Current Consumption        |
| Continuous Conversion Mode (ADCS:MD1,MD0= "10 <sub>B</sub> ") | 134                                                |
| Conversion Modes of 8-/10-bit A/D Converter                   | Cycle Count                                        |
|                                                               | Execution Cycle Count593                           |
| Operation of Continuous Conversion Mode 363                   |                                                    |
| Operation of Pause-conversion Mode                            | D                                                  |
| Operation of Single-shot Conversion Mode 361                  | Data Counter                                       |
| Pause-conversion Mode (ADCS:MD1,MD0= "11 <sub>B</sub> ")      | Data Counter (DCT)76                               |
| 359                                                           | Data Frame                                         |
| Setting of Continuous Conversion Mode 362                     | Processing for Reception of Data Frame and Remote  |
| Setting of Pause-conversion Mode                              | frame491                                           |
| Setting of Single-shot Conversion Mode 360                    |                                                    |
|                                                               | Data Polling Data Polling 640                      |
|                                                               |                                                    |

| Data Polling Flag                                   | Use of the "DIV A,Ri" and "DIVW A,RWi"                       |
|-----------------------------------------------------|--------------------------------------------------------------|
| Data Polling Flag (DQ7)541                          | Instructions without Precautions 53                          |
|                                                     | DIVW                                                         |
| Data Read                                           | Precautions for Use of "DIV A,Ri" and                        |
| Data Read by Read Access636                         | "DIVW A,RWi" Instructions 52                                 |
| Data Register                                       | Use of the "DIV A,Ri" and "DIVW A,RWi"                       |
| List of Message Buffer (data register)451           | Instructions without Precautions 53                          |
| List of Message Buffers                             | DLC Registers                                                |
| (DLC registers and Data registers) 450              | List of Message Buffers                                      |
| DCT                                                 | (DLC Registers and Data registers) 450                       |
| Data Counter (DCT)76                                | DQ5                                                          |
| DDR                                                 | Timing Limit Exceeded Flag (DQ5) 543                         |
| Port Direction Register (DDR)172                    | DQ6                                                          |
| Delayed Interrupt Generation Module                 | Toggle Bit Flag (DQ6) 542                                    |
| Block Diagram of Delayed Interrupt Generation       | DQ7                                                          |
| Module85                                            | Data Polling Flag (DQ7)541                                   |
| Explanation of Operation of Delayed Interrupt       | DTP                                                          |
| Generation Module88                                 | DTP Function                                                 |
| Overview of Delayed Interrupt Generation Module     | Program Example of DTP Function                              |
| 84                                                  | DTP/External Interrupt                                       |
| Precautions when Using Delayed Interrupt Generation | Block Diagram of DTP/External Interrupt 315                  |
| Module89                                            | DTP/External Interrupt Function                              |
| Program Example of Delayed Interrupt Generation     | DTP/External Interrupt Operation                             |
| Module90                                            | List of Registers and Reset Values in DTP/                   |
| Delayed Interrupt Request Generate/cancel Register  | External Interrupt                                           |
| Delayed Interrupt Request Generate/cancel Register  | Pins of DTP/External Interrupt317                            |
| (DIRR)87                                            | Precautions when Using DTP/External Interrupt                |
| Descriptor                                          |                                                              |
| Extended Intelligent I/O Service Descriptor (ISD)   | Program Example of DTP/External Interrupt Function           |
| 76                                                  |                                                              |
| Detailed Explanation                                | Setting of DTP/External Interrupt327                         |
| Detailed Explanation of Flash Memory Write/erase    | DTP/External Interrupt Enable Register                       |
| 544                                                 | DTP/External Interrupt Enable Register (ENIR1)               |
| Detect Address                                      | 321                                                          |
| Setting Detect Address516                           | DTP/External Interrupt Factor Register                       |
| Detect Address Setting Registers                    | DTP/External Interrupt Factor Register (EIRR1)               |
| Detect Address Setting Registers (PADR0 to PADR5)   | 319                                                          |
| 513                                                 |                                                              |
| Functions of Detect Address Setting Registers       | E                                                            |
| 514                                                 | E <sup>2</sup> PROM                                          |
| Detection Level Setting Register                    | E <sup>2</sup> PROM Memory Map518                            |
| Detection Level Setting Register (ELVR1)323         | Operation of Address Match Detection Function at             |
| Device                                              | Storing Patch Program in E <sup>2</sup> PROM 520             |
| Handling the Device21                               | System Configuration and E <sup>2</sup> PROM Memory Map      |
| Direct Addressing                                   | 517                                                          |
| Direct Addressing580                                | ECCR                                                         |
| Direct Pin Access                                   | Extended Communication Control Register (ECCR)               |
| LIN-UART Direct Pin Access                          | 403                                                          |
| DIRR                                                | Effective Address                                            |
| Delayed Interrupt Request Generate/cancel Register  | Effective Address Field 579, 596                             |
| (DIRR)87                                            | El <sup>2</sup> OS                                           |
| DIV                                                 | 16-bit I/O Timer Interrupt and EI <sup>2</sup> OS            |
| Precautions for Use of "DIV A,Ri" and               | 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS 358 |
| "DIVW A,RWi" Instructions52                         | Conversion Using El <sup>2</sup> OS                          |
| ~                                                   |                                                              |

| Correspondence between 16-bit Reload Timer                   | External Clock                                       |
|--------------------------------------------------------------|------------------------------------------------------|
| Interrupt and EI <sup>2</sup> OS251                          | Connection of an Oscillator or an External Clock     |
| Correspondence between Timebase Timer Interrupt              | to the Microcontroller108                            |
| and EI <sup>2</sup> OS187                                    | External Interrupt                                   |
| Correspondence to EI <sup>2</sup> OS Function                | Block Diagram of DTP/External Interrupt315           |
| EI <sup>2</sup> OS Function of 16-bit Reload Timer           | DTP/External Interrupt Enable Register (ENIR1)       |
| EI <sup>2</sup> OS Function of 8-/10-bit A/D Converter 358   | 321                                                  |
| EI <sup>2</sup> OS Operation Flow79                          | DTP/External Interrupt Factor Register (EIRR1)       |
| Extended Intelligent I/O Service (EI <sup>2</sup> OS) 57, 74 | 319                                                  |
| LIN-UART Interrupts and EI <sup>2</sup> OS408                | DTP/External Interrupt Function314                   |
| El <sup>2</sup> OS Status Register                           | DTP/External Interrupt Operation329                  |
| EI <sup>2</sup> OS Status Register (ISCS)78                  | External Interrupt Function331                       |
| EIRR                                                         | List of Registers and Reset Values in DTP/           |
| DTP/External Interrupt Factor Register (EIRR1)               | External Interrupt318                                |
| 319                                                          | Pins of DTP/External Interrupt317                    |
| ELVR                                                         | Precautions when Using DTP/External Interrupt        |
| Detection Level Setting Register (ELVR1) 323                 | 333                                                  |
| Enable Sector Protect                                        | Program Example of DTP/External Interrupt Function   |
|                                                              | 335                                                  |
| Enable Sector Protect/verify Sector Protect642               | Selection of External Interrupt Factor325            |
| ENIR                                                         | Setting of DTP/External Interrupt327                 |
| DTP/External Interrupt Enable Register (ENIR1)               | External Reset                                       |
| 321                                                          | Block Diagrams of the External Reset Pin125          |
| Erase                                                        | External Single Clock                                |
| Detailed Explanation of Flash Memory Write/erase             | Sub-clock Mode with External Single Clock Product    |
| 544                                                          | 116                                                  |
| Erasing                                                      |                                                      |
| Erasing All Data in the Flash Memory (erasing chips)         | F                                                    |
| 548                                                          |                                                      |
| Erasing Chip                                                 | F <sup>2</sup> MC-16LX                               |
| Erasing All Data in the Flash Memory (erasing chips)         | F <sup>2</sup> MC-16LX Instruction List600           |
| 548                                                          | Features                                             |
| Erasing Chip in the Flash Memory548                          | Features7                                            |
| ESCR                                                         | FF Bank                                              |
| Extended Status/control Register (ESCR) 401                  | Access to FF Bank by ROM Mirroring Function          |
| Evaluation Chip                                              | 526                                                  |
| Block Diagram of Evaluation Chip                             | Flag Change Disable Prefix                           |
|                                                              | Flag Change Disable Prefix (NCC)49                   |
| Event Count Mode                                             |                                                      |
| Event Count Mode                                             | Flag Set Timing                                      |
| Operation in Event Count Mode                                | Reception Interrupt Generation and Flag Set Timing   |
| Setting of Event Count Mode                                  | 409                                                  |
| Event Counter Mode                                           | Transmission Interrupt Generation and Flag Set       |
| Program Example in Event Counter Mode264                     | Timing411                                            |
| Exceptions                                                   | Flash                                                |
| Exceptions58                                                 | Block Diagram of Flash/Mask ROM Version11            |
| Extended Communication Control Register                      | Flash Memory                                         |
| Extended Communication Control Register (ECCR)               | 512K-bit Flash Memory Features530                    |
| 403                                                          | Block Diagram of the Entire Flash Memory531          |
| Extended Intelligent I/O Service                             | Detailed Explanation of Flash Memory Write/erase     |
| Extended Intelligent I/O Service (EI <sup>2</sup> OS) 57, 74 | 544                                                  |
| Extended Intelligent I/O Service Descriptor (ISD)            | Erasing All Data in the Flash Memory (erasing chips) |
| 76                                                           | 548                                                  |
| Extended Status/control Register                             | Erasing Chip in the Flash Memory548                  |
| Extended Status/control Register (ESCR) 401                  | Flash Memory Control Signals533                      |
| Extended builds/control register (Escry)                     | Notes on Using Flash Memory550                       |

| Sector Configuration of the 512K-bit Flash Memory  | I/O Maps                                          |         |
|----------------------------------------------------|---------------------------------------------------|---------|
| 531                                                | I/O Maps (00XX Addresses)                         | 568     |
| Setting the Flash Memory to the Read/reset State   | I/O Pins                                          |         |
| 545                                                | Status of I/O Pins (Single-chip Mode)             | 156     |
| Writing Data to the Flash Memory                   | I/O Port                                          |         |
| Writing to the Flash Memory                        | I/O Port Registers                                | 169     |
| Writing to/erasing Flash Memory530                 | I/O Ports                                         | 168     |
| Flash Memory Control Status Register               | I/O Timer                                         |         |
| Flash Memory Control Status Register (FMCS)        | 16-bit I/O Timer Interrupt and EI <sup>2</sup> OS | 228     |
| 530, 535                                           | Block Diagram of 16-bit I/O Timer                 |         |
| Flash Memory Mode                                  | Functions of 16-bit I/O Timer                     | 210     |
| Flash Memory Mode533                               | Generation of Interrupt Request from 16-bit I/C   | ) Timer |
| Flash Memory Write                                 |                                                   |         |
| Detailed Explanation of Flash Memory Write/erase   | Interrupts of 16-bit I/O Timer                    | 227     |
| 544                                                | Module Configuration of 16-bit I/O Timer          |         |
| Flash Microcomputer Programmer                     | Pins of 16-bit I/O Timer                          |         |
| Example of Minimum Connection to Flash             | Precautions when Using 16-bit I/O Timer           |         |
| Microcomputer Programmer                           | Program Example of 16-bit I/O Timer               |         |
| (Power supplied from programmer)563                | ICE                                               | 20 .    |
| Example of Minimum Connection to Flash             |                                                   | 224     |
|                                                    | Input Capture Edge Register (ICE)                 | 224     |
| microcontroller Programmer561                      | ICR                                               |         |
| Flash Security                                     | Interrupt Control Register (ICR)                  | 61      |
| Behavior Under the Flash Security Feature 551      | ICS                                               |         |
| How to Disable the Flash Security Feature551       | Input Capture Control Status Registers (ICS01,    | (ICS23, |
| How to Enable the Flash Security Feature551        |                                                   | 221     |
| FMCS                                               | ID                                                |         |
| Flash Memory Control Status Register (FMCS)        | Setting ID                                        | 494     |
| 530, 535                                           | ID Registers                                      |         |
| Frame Format                                       | List of Message Buffers (ID registers)            | 448     |
| Setting Frame Format494                            |                                                   | 440     |
| Free-run Timer                                     | ILSR                                              | 176     |
| Block Diagram of 16-bit Free-run Timer213          | Input Level Select Register (ILSR)                | 176     |
| Explanation of Operation of 16-bit Free-run Timer  | Indirect Addressing                               |         |
| 229                                                | Indirect Addressing                               | 586     |
| 229                                                | Initialized State                                 |         |
| 11                                                 | Operating Mode in Initialized State               | 115     |
| Н                                                  | Input Capture                                     |         |
| HALT                                               | Block Diagram of Input Capture                    | 214     |
| Conditions for Canceling Bus Operation Stop        | Setting of Input Capture                          |         |
| (HALT=0)457                                        | Input Capture Control Status Registers            |         |
| Conditions for Setting Bus Operation Stop (HALT=1) | Input Capture Control Status Registers (ICS01,    | ICS23)  |
| 457                                                | input Cupture Control Status Registers (16501,    |         |
| State during Bus Operation Stop (HALT=1) 457       |                                                   |         |
| Hardware Interrupt                                 | Input Capture Edge Register                       | 224     |
| Hardware Interrupt Operation68                     | Input Capture Edge Register (ICE)                 | 224     |
| Hardware Interrupts                                | Input Capture Register                            |         |
| Occurrence and Release of Hardware Interrupt69     | Input Capture Register (IPCP)                     | 223     |
| <u>.</u>                                           | Input Level Select Register                       |         |
| Structure of Hardware Interrupt67                  | Input Level Select Register (ILSR)                | 176     |
| Hardware Sequence Flags                            | Input-output Circuits                             |         |
| Hardware Sequence Flags539                         | Input-output Circuits                             | 17      |
|                                                    | Instruction                                       |         |
| I                                                  | Exception due to Execution of an Uni              | defined |
| I/O Area                                           | Instruction                                       |         |
| I/O Area30                                         | Execution of an Undefined Instruction             |         |
| 1/O AICa                                           |                                                   |         |
|                                                    | Interrupt Disable Instructions                    | ວ ເ     |

| Precautions for Use of "DIV A,Ri" and                        | Transmission Interrupt Generation and Flag Set                           |
|--------------------------------------------------------------|--------------------------------------------------------------------------|
| "DIVW A,RWi" Instructions 52                                 | Timing411                                                                |
| Restrictions on Interrupt Disable Instructions               | Watch Timer Interrupt275                                                 |
| and Prefix Instructions51                                    | Watch Timer Interrupt and EI <sup>2</sup> OS Transfer Function           |
| Use of the "DIV A,Ri" and "DIVW A,RWi"                       | 275                                                                      |
| Instructions without Precautions 53                          | Interrupt Causes                                                         |
| Instruction List                                             | Interrupt Causes, interrupt Vectors, and Interrupt                       |
| F <sup>2</sup> MC-16LX Instruction List600                   | control Registers646                                                     |
| Instruction Map                                              | Interrupt Control Register                                               |
| Structure of Instruction Map614                              | Interrupt Causes, interrupt Vectors, and Interrupt                       |
| Instruction Presentation                                     | control Registers646                                                     |
|                                                              | Interrupt Control Register (ICR)61                                       |
| Description of Instruction Presentation Items and symbols    | Interrupt Disable Instructions                                           |
| -                                                            | Interrupt Disable Instructions51                                         |
| Instruction Types                                            |                                                                          |
| Instruction Types577                                         | Restrictions on Interrupt Disable Instructions and Prefix Instructions51 |
| Inter-CPU Connection                                         |                                                                          |
| Inter-CPU Connection Method421                               | Interrupt Number                                                         |
| Internal Clock Mode                                          | Details of Pins and Interrupt Number212                                  |
| Internal Clock Mode238                                       | Details of Pins and Interrupt Numbers316                                 |
| Operation in Internal Clock Mode255                          | Interrupt Number85                                                       |
| Program Example in Internal Clock Mode 263                   | Interrupt Request                                                        |
| Setting of Internal Clock Mode254                            | Generation of Interrupt Request from 16-bit I/O Timer                    |
| Interrupt                                                    | 216                                                                      |
| 16-bit I/O Timer Interrupt and EI <sup>2</sup> OS            | Generation of Interrupt Request from 16-bit Reload                       |
| 8-/10-bit A/D Converter Interrupt and EI <sup>2</sup> OS 358 | Timer244                                                                 |
| Cancellation of Standby Mode by Interrupt 157                | Generation of Interrupt Request from 8-/16-bit                           |
| Correspondence between 16-bit Reload Timer                   | PPG Timer291                                                             |
| Interrupt and EI <sup>2</sup> OS251                          | Generation of Interrupt Request from Timebase Timer                      |
| Correspondence between Timebase Timer Interrupt              | 184                                                                      |
| and El <sup>2</sup> OS187                                    | Generation of Interrupt Request from Watch Timer                         |
| Generation of Interrupt from 8-/10-bit A/D Converter         | 272                                                                      |
|                                                              | Interrupt Vector                                                         |
| Hardware Interrupt Operation                                 | Interrupt Causes, interrupt Vectors, and Interrupt                       |
| Hardware Interrupts56, 67                                    | control Registers646                                                     |
| Interrupt Disable Instructions51                             | Interrupt Vector59                                                       |
| Interrupt Flow                                               | List of Interrupt Vectors72, 644                                         |
| Interrupt Number85                                           | Interval Timer                                                           |
| Interrupts of 16-bit Reload Timer                            | Interval Timer Function180, 188, 268, 276                                |
| Interrupt of 8-/16-bit PPG Timer                             |                                                                          |
| Interrupts of 8-/16-bit PPG Timer                            | IPCP                                                                     |
|                                                              | Input Capture Register (IPCP)223                                         |
| Interrupt of A/D Converter                                   | ISCS                                                                     |
| Interrupt of Timebase Timer                                  | EI <sup>2</sup> OS Status Register (ISCS)                                |
| LIN-UART Interrupts                                          | ISD                                                                      |
|                                                              | Extended Intelligent I/O Service Descriptor (ISD)                        |
| Multiple Interrupts                                          | 76                                                                       |
| Occurrence and Release of Hardware Interrupt                 |                                                                          |
| 69                                                           | L                                                                        |
| Reception Interrupt Generation and Flag Set Timing           | _                                                                        |
|                                                              | Last Event Indicator Register                                            |
| Restrictions on Interrupt Disable Instructions and           | Last Event Indicator Register (LEIR)458                                  |
| prefix Instructions                                          | LEIR                                                                     |
| Software Interrupt Operation                                 | Last Event Indicator Register (LEIR)458                                  |
| Software Interrupts                                          | LIN Master Device                                                        |
| Structure of Hardware Interrupt67                            | LIN-UART as LIN Master Device439                                         |
| Structure of Software Interrupts                             |                                                                          |

| LIN-master-slave Communication                      | M                                                       |
|-----------------------------------------------------|---------------------------------------------------------|
| LIN-master-slave Communication Function438          | Machine Clock                                           |
| LIN-UART                                            | Machine Clock                                           |
| Block Diagram of LIN-UART387                        | Mask ROM                                                |
| Block Diagram of LIN-UART Pins391                   | Block Diagram of Flash/Mask ROM Version 11              |
| LIN-UART as LIN Master Device439                    |                                                         |
| LIN-UART Baud Rate Selection413                     | Master-slave Communication                              |
| LIN-UART Direct Pin Access432                       | Master-slave Communication Function                     |
| LIN-UART Functions382                               | MB90360 Series                                          |
| LIN-UART Interrupts406                              | Features of MB90360 Series                              |
| LIN-UART Interrupts and EI <sup>2</sup> OS408       | MB90F362                                                |
| LIN-UART Pins                                       | Basic Configuration of Serial Programming               |
| LIN-UART Registers392                               | Connection with MB90F362/T(S),                          |
| Notes on Using LIN-UART441                          | MB90F367/T(S) 554                                       |
| Operation of LIN-UART420                            | MB90F367                                                |
| LIN-UART Serial Mode Register                       | Basic Configuration of Serial Programming               |
| LIN-UART Serial Mode Register (SMR)395              | Connection with MB90F362/T(S),                          |
| Low Voltage                                         | MB90F367/T(S) 554                                       |
| Block Diagram of Low Voltage/CPU Operating          | MB90V340                                                |
| Detection Reset Circuit374                          | CAN Direct Mode Register (CDMR)                         |
| Operating of Low Voltage/CPU Operating Detection    | (Only MB90V340)502                                      |
| Reset Circuit378                                    | MD                                                      |
| Sample Program for Low Voltage/CPU Operating        | Continuous Conversion Mode                              |
| Detection Reset Circuit380                          | (ADCS:MD1,MD0= "10 <sub>B</sub> " ) 359                 |
| Low Voltage Detection                               | Pause-conversion Mode                                   |
| Status of Reset Cause Bit and Low Voltage Detection | (ADCS:MD1,MD0= "11 <sub>B</sub> " ) 359                 |
| Bit130                                              | Single-shot Conversion Mode                             |
| Low Voltage Detection Reset Circuit                 | $(ADCS:MD1,MD0="00_B" \text{ or }"01_B")$               |
| Low Voltage Detection Reset Circuit372              | 359                                                     |
| Notes on Using Low Voltage Detection Reset Circuit  | Memory Access Modes                                     |
| 379                                                 | Outline of Memory Access Modes                          |
| Low Voltage/CPU Operating Detection Reset Control   | Memory Map                                              |
| Register                                            | E <sup>2</sup> PROM Memory Map518                       |
| Low Voltage/CPU Operating Detection Reset           | Memory Map 32                                           |
| Control Register (LVRC)376                          | System Configuration and E <sup>2</sup> PROM Memory Map |
| Low-Power Consumption                               | 517                                                     |
| Block Diagram of the Low-Power Consumption          | Memory Space                                            |
| Control Circuit137                                  | Memory Space in Each Bus Mode 165                       |
| Low-Power Consumption Mode Control Register         | Multi-byte Data Allocation in Memory Space 36           |
| Low-Power Consumption Mode Control Register         | Outline of CPU Memory Space                             |
| (LPMCR)139                                          | Message Buffer                                          |
| Notes on Accessing the Low-Power Consumption        | Caution for Disabling Message Buffers by BVAL Bits      |
| Mode Control Register (LPMCR) to                    | 503                                                     |
| Enter the Standby Mode158                           | List of Message Buffer (data register) 451              |
| LPMCR                                               | List of Message Buffers (DLC registers and Data         |
| Low-Power Consumption Mode Control Register         | registers)                                              |
| (LPMCR)139                                          | List of Message Buffers (ID registers)448               |
| Notes on Accessing the Low-Power Consumption        | Message Buffers                                         |
| Mode Control Register (LPMCR) to                    | Procedure for Reception by Message Buffer (x)           |
| Enter the Standby Mode158                           | 498                                                     |
| LVRC                                                | Procedure for Transmission by Message Buffer (x)        |
| Low Voltage/CPU Operating Detection Reset Control   | Setting Confirmation of Multi level Masses Buffer       |
| Register (LVRC)376                                  | Setting Configuration of Multi-level Message Buffer     |
|                                                     | 500                                                     |

| Message Buffer Control Registers                    | Operation Enable Bit                                  |
|-----------------------------------------------------|-------------------------------------------------------|
| Message Buffer Control Registers452                 | Operation Enable Bit421                               |
| Microcontroller                                     | Operation Mode                                        |
| Connection of an Oscillator or an External Clock    | CPU Intermittent Operation Mode142                    |
| to the Microcontroller108                           | Operation in Asynchronous LIN Mode                    |
| Minimum Connection                                  | (operation mode 3)429                                 |
| Example of Minimum Connection to Flash              | Operation in Synchronous Mode (operation mode 2)      |
| Microcomputer Programmer563                         | 426                                                   |
| Example of Minimum Connection to Flash              | Operation Modes of 16-bit Reload Timer238             |
| microcontroller Programmer561                       | Setting for 16-bit PPG Output Operation Mode          |
| Mode Data                                           | Setting for 8+8-bit PPG Output Operation Mode         |
| Mode Data                                           | 307                                                   |
| Status of Pins after Mode Data is Read              | Setting for 8-bit PPG Output 2-channel                |
| Mode Fetch                                          | Independent Operation Mode301                         |
| Mode Fetch                                          | Operation Status                                      |
| Mode Pins                                           | Operation Status during Standby Mode143               |
| Mode Pins                                           | Oscillating Clock Frequency                           |
| Module Configuration                                | Oscillating Clock Frequency and Serial Clock          |
| Module Configuration of 16-bit I/O Timer 210        | Input Frequency556                                    |
| Multi-byte Data                                     | Oscillation Circuit                                   |
| Accessing Multi-byte Data36                         | Prohibition Setting of CR Oscillation Circuit         |
| Multi-byte Data Allocation                          | and Clock Supervisor115                               |
| Multi-byte Data Allocation in Memory Space 36       | Reoperating Setting of CR Oscillation Circuit         |
| Multi-level Message Buffer                          | and Clock Supervisor115                               |
| Setting Configuration of Multi-level Message Buffer | Oscillation Stabilization Wait                        |
| 500                                                 | Oscillation Stabilization Wait and Reset State124     |
| Multiple Interrupts                                 | Oscillation Stabilization Wait Interval107            |
| Multiple Interrupts71                               | Oscillation Stabilization Wait Time                   |
| Multiplier                                          | Oscillation Stabilization Wait Time157                |
| Selection of a PLL Clock Multiplier104              | Oscillation Stabilization Wait Time Timer             |
|                                                     | of Subclock277                                        |
| N                                                   | Reset Causes and Oscillation Stabilization Wait Times |
| NCC                                                 | 123                                                   |
| Flag Change Disable Prefix (NCC)49                  | Oscillator                                            |
| Node Status                                         | Connection of an Oscillator or an External Clock      |
| Correspondence between Node Status Bit and Node     | to the Microcontroller108                             |
| Status456                                           | Others                                                |
|                                                     | Others                                                |
| 0                                                   | Overall Control Registers                             |
| Operating Detection Reset Circuit                   | List of overall Control Registers446                  |
| Block Diagram of Low Voltage/CPU Operating          | Overall Control Registers452                          |
| Detection Reset Circuit                             | Р                                                     |
| Operating of Low Voltage/CPU Operating Detection    | r                                                     |
| Reset Circuit378                                    | Package Dimensions                                    |
| Sample Program for Low Voltage/CPU Operating        | Package Dimensions12                                  |
| Detection Reset Circuit380                          | PACSR                                                 |
| Operating Mode                                      | Address Detection Control Register 0 (PACSR0)         |
| CPU Intermittent Operating Mode                     | 509                                                   |
| CPU Operating Modes and Current Consumption         | Address Detection Control Register 1 (PACSR1)         |
| 134                                                 | 511                                                   |
| Operation Clock                                     | PADR                                                  |
| Supply of Operation Clock191                        | Detect Address Setting Registers (PADR0 to PADR5) 513 |
|                                                     |                                                       |

| Patch Processing                                | Pins of 8-/16-bit PPG Timer                        |
|-------------------------------------------------|----------------------------------------------------|
| Flow of Patch Processing for Patch Program520   | Precautions when Using 8-/16-bit PPG Timer 310     |
| Patch Program                                   | PPGC Operation Mode Control Register               |
| Flow of Patch Processing for Patch Program520   | PPGC Operation Mode Control Register (PPGCC)       |
| Pause-conversion Mode                           |                                                    |
| Operation of Pause-conversion Mode365           | PPGC/D Count Clock Select Register                 |
| Pause-conversion Mode                           | PPGC/D Count Clock Select Register (PPGCD)         |
| (ADCS:MD1,MD0= "11 <sub>B</sub> " )359          | 296                                                |
| Setting of Pause-conversion Mode                | PPGCC                                              |
| PC                                              |                                                    |
|                                                 | PPGC Operation Mode Control Register (PPGCC)292    |
| Program Counter (PC)45                          |                                                    |
| PDR                                             | PPGCD                                              |
| Port Data Register (PDR)170                     | PPGC/D Count Clock Select Register (PPGCD)         |
| Pin                                             |                                                    |
| Details of Pins and Interrupt Number212         | PPGD Operation Mode Control Register (PPGCD)       |
| Mode Pins163                                    | 294                                                |
| Pin Functions14                                 | PPGD Operation Mode Control Register               |
| Pins of 16-bit I/O Timer216                     | PPGD Operation Mode Control Register (PPGCD)       |
| Status of I/O Pins (Single-chip Mode)156        | 294                                                |
| Status of Pins after Mode Data is Read132       | Prefix                                             |
| Status of Pins During a Reset132                | Bank Select Prefix48                               |
| PLL Clock Multiplier                            | Common Register Bank Prefix (CMR)                  |
| Selection of a PLL Clock Multiplier104          | Flag Change Disable Prefix (NCC)                   |
| Port Data Register                              | Restrictions on Interrupt Disable Instructions and |
| Port Data Register (PDR)170                     | prefix Instructions51                              |
| Port Direction Register                         | Prefix Instructions                                |
| Port Direction Register (DDR)172                | Restrictions on Interrupt Disable Instructions     |
|                                                 | and Prefix Instructions                            |
| Power Supplied From Programmer                  | Prescaler Settings                                 |
| Example of Serial Programming Connection        | Prescaler Settings                                 |
| (Power Supplied From Programmer)                | _                                                  |
| 559                                             | Processor Status                                   |
| PPG                                             | Processor Status (PS)                              |
| Channels and PPG Pins of PPG Timers285          | Program Counter                                    |
| Setting for 16-bit PPG Output Operation Mode    | Program Counter (PC)45                             |
| 304                                             | Program Example                                    |
| Setting for 8+8-bit PPG Output Operation Mode   | Program Example for Address Match Detection        |
| 307                                             | Function522                                        |
| Setting for 8-bit PPG Output 2-channel          | Program Example in Event Counter Mode 264          |
| Independent Operation Mode301                   | Program Example in Internal Clock Mode 263         |
| PPG Reload Registers                            | Program Example of 16-bit I/O Timer234             |
| PPG Reload Registers                            | Program Example of Delayed Interrupt Generation    |
| (PRLLC/PRLHC,PRLLD/PRLHD)298                    | Module 90                                          |
| PPG Timer                                       | Program Example of DTP Function                    |
| Block Diagram of 8-/16-bit PPG Timer C286       | Program Example of DTP/External Interrupt Function |
| Block Diagram of 8-/16-bit PPG Timer D288       | 335                                                |
| Channels and PPG Pins of PPG Timers285          | Program Example of Timebase Timer193               |
| Functions of 8-/16-bit PPG Timer282             | Program Example of Watch Timer                     |
| Generation of Interrupt Request from 8-/16-bit  | Program Examples of Watchdog Timer 208             |
| PPG Timer291                                    | Program Execution                                  |
| Interrupt of 8-/16-bit PPG Timer299             | Program Execution                                  |
| Interrupts of 8-/16-bit PPG Timer299            | PS PS                                              |
| List of Registers and Reset Values of 8-/16-bit | Processor Status (PS)42                            |
| PPG Timer291                                    | 110ccsso1 Status (1 S)42                           |
| Operation Modes of 8-/16-bit PPG Timer283       |                                                    |
| Operation of 8-/16-bit PPG Timer300             |                                                    |
| 1                                               |                                                    |

| PSCCR                                                                          | Operation Modes of 16-bit Reload Timer238             |
|--------------------------------------------------------------------------------|-------------------------------------------------------|
| Configuration of the PLL/Subclock Control Register                             | Pins of 16-bit Reload Timer242                        |
| (PSCCR)101                                                                     | Precautions when Using 16-bit Reload Timer            |
| PUCR                                                                           | 262                                                   |
| Block Diagram of Pull-up Control Register (PUCR)                               | Setting of 16-bit Reload Timer252                     |
| 174                                                                            | Remote Frame                                          |
| Pull-up Control Register (PUCR) 174                                            | Processing for Reception of Data Frame                |
| Pull-up Control Register                                                       | and Remote Frame491                                   |
| Block Diagram of Pull-up Control Register (PUCR)                               | Reset                                                 |
| 174                                                                            | 16-bit Reload Timer Registers and Reset Value         |
| Pull-up Control Register (PUCR) 174                                            | 243                                                   |
|                                                                                | Block Diagrams of the External Reset Pin125           |
| R                                                                              | Causes of a Reset120                                  |
|                                                                                | Clock Selection Register and List of Reset Value      |
| RAM                                                                            | 97                                                    |
| RAM area30                                                                     | List of Registers and Reset Values86                  |
| RDR                                                                            | List of Registers and Reset Values in DTP/            |
| Reception Data Register (RDR)399                                               | External Interrupt318                                 |
| Read                                                                           | List of Registers and Reset Values of 8-/10-bit       |
| Setting the Flash Memory to the Read/reset State                               | A/D Converter345                                      |
| 545                                                                            | List of Registers and Reset Values of 8-/16-bit       |
| Read Access                                                                    | PPG Timer291                                          |
| Data Read by Read Access636                                                    | List of Registers and Reset Values of Address         |
| Receive Overrun                                                                | Match Detection Function508                           |
| Receive Overrun                                                                | List of Registers and Reset Values of ROM             |
|                                                                                | Mirroring Function Select Module527                   |
| Received Message                                                               | List of Registers and Reset Values of Timebase Timer  |
| Storing Received Message                                                       | 184                                                   |
| Reception                                                                      | List of Registers and Reset Values of Watch Timer     |
| Completing Reception                                                           | 272                                                   |
| Procedure for Reception by Message Buffer (x)                                  | List of Registers and Reset Values of Watchdog Timer  |
| 498                                                                            | 201                                                   |
| Processing for Reception of Data Frame and Remote                              | Oscillation Stabilization Wait and Reset State124     |
| Frame                                                                          | Overview of Reset Operation126                        |
| Reception Flowchart of the CAN Controller 493                                  | Reset Check By Clock Supervisor117                    |
| Reception Data Register                                                        | Status of Pins during a Reset132                      |
| Reception Data Register (RDR)399                                               | Reset Cause                                           |
| Reception Interrupt                                                            | Reset Cause Bits128                                   |
| Reception Interrupt Generation and Flag Set Timing                             | Reset Cause                                           |
| 409                                                                            | Notes about Reset Cause Bits131                       |
| Register Bank                                                                  | Reset Causes and Oscillation Stabilization Wait Times |
| Register Bank46                                                                | 123                                                   |
| Register Bank Pointer                                                          | Status of Reset Cause Bit and Low Voltage Detection   |
| Register Bank Pointer (RP)43                                                   | Bit130                                                |
| Reload Counter                                                                 | Reset State                                           |
| Function of Reload Counter                                                     | Setting the Flash Memory to the Read/reset State      |
| Reload Timer                                                                   | 545                                                   |
| 16-bit Reload Timer Registers and Reset Value                                  | ROM Mirroring                                         |
| 243                                                                            | Access to FF Bank by ROM Mirroring Function           |
| Block Diagram of 16-bit Reload Timer                                           | Access to 11 Bank by ROW Winforning Function 526      |
|                                                                                | Block Diagram of ROM Mirroring Function Select        |
| Correspondence between 16-bit Reload Timer Interrupt and EI <sup>2</sup> OS251 | Module526                                             |
| EI <sup>2</sup> OS Function of 16-bit Reload Timer                             |                                                       |
| Generation of Interrupt Request from 16-bit                                    | ROM Mirroring Function Select Module                  |
| Reload Timer244                                                                | Block Diagram of ROM Mirroring Function Select        |
| Interrupts of 16-bit Reload Timer                                              | Module526                                             |
| interrupts of 10-off Reload Tiller201                                          |                                                       |

| List of Registers and Reset Values of ROM Mirroring | Signal Mode                                       |
|-----------------------------------------------------|---------------------------------------------------|
| Function Select Module527                           | Signal Mode                                       |
| ROM Mirroring Function Select Register              | Single Clock                                      |
| ROM Mirroring Function Select Register (ROMM)       | Sub-clock Mode with External Single Clock Product |
| 528                                                 | 116                                               |
| ROMM                                                | Single-chip Mode                                  |
| ROM Mirroring Function Select Register (ROMM)       | Status of I/O Pins (Single-chip Mode)             |
| 528                                                 | Single-shot Conversion Mode                       |
| ROM Security Function                               | Operation of Single-shot Conversion Mode 361      |
| Overview of ROM Security Function566                | Setting of Single-shot Conversion Mode 360        |
| RP                                                  | Single-shot Conversion Mode                       |
| Register Bank Pointer (RP)43                        | (ADCS:MD1,MD0= $"00_B"$ or $"01_B"$ )             |
|                                                     | 359                                               |
| RST                                                 |                                                   |
| RST and RY/BY Timing641                             | Sleep Mode  Return from Sleep Mode                |
| RY                                                  | Return from Sleep Mode                            |
| RST and RY/BY Timing641                             | Switching to Sleep Mode                           |
| RY/BY Timing during Writing/erasing641              | SMR                                               |
|                                                     | LIN-UART Serial Mode Register (SMR) 395           |
| S                                                   | Software Interrupt                                |
| Occupie Borrows                                     | Software Interrupt Operation72                    |
| Sample Program                                      | Software Interrupts57, 72                         |
| Sample Program for Low Voltage/CPU Operating        | Structure of Software Interrupts72                |
| Detection Reset Circuit380                          | Special Registers                                 |
| Sampling Time                                       | Special Registers37                               |
| Setting of Sampling Time (ST2 to ST0 bits)354       | SSP                                               |
| SCR                                                 | User Stack Pointer (USP) and System Stack Pointer |
| Serial Control Register (SCR)393                    | (SSP)                                             |
| Sector Configuration                                | * *                                               |
| Sector Configuration of the 512K-bit Flash Memory   | SSR                                               |
| 531                                                 | Serial Status Register (SSR)                      |
|                                                     | ST                                                |
| Sector Erase Command                                | Setting of Sampling Time (ST2 to ST0 bits) 354    |
| Chip Erase/sector Erase Command Sequence639         | Standby Mode                                      |
| Sector Protect                                      | Cancellation of Standby Mode by Interrupt 157     |
| Enable Sector Protect/verify Sector Protect642      | Notes on Accessing the Low-Power Consumption      |
| Temporary Sector Protect Cancellation643            | Mode Control Register (LPMCR) to                  |
| Serial Clock                                        | Enter the Standby Mode                            |
| Oscillating Clock Frequency and Serial Clock        | Note on Canceling Standby Mode 157                |
| Input Frequency556                                  | Notes on the Transition to Standby Mode 157       |
| Serial Control Register                             | Operation Status during Standby Mode 143          |
| Serial Control Register (SCR)393                    | Standby Mode                                      |
| Serial Programming Connection                       | Transition to Standby Mode                        |
| Basic Configuration of Serial Programming           | Status Bit                                        |
| Connection with MB90F362/T(S),                      | Correspondence between Node Status Bit and Node   |
| MB90F367/T(S)554                                    | Status                                            |
| Example of Serial Programming Connection            |                                                   |
| (Power Supplied From Programmer) 559                | Status Change                                     |
| Example of Serial Programming Connection            | Status Change Diagram                             |
| (User Power Supply Used)557                         | Stop Mode                                         |
|                                                     | Stop Mode                                         |
| Serial Status Register                              | Storing Patch Program                             |
| Serial Status Register (SSR)397                     | Operation of Address Match Detection Function at  |
| Setting                                             | Storing Patch Program in E <sup>2</sup> PROM      |
| Setting for 16-bit PPG Output Operation Mode        | 520                                               |
| 304                                                 | Structure                                         |
|                                                     | Structure                                         |
|                                                     |                                                   |

| Sub-clock                                               | Timer Control Status Register                                             |  |  |
|---------------------------------------------------------|---------------------------------------------------------------------------|--|--|
| Oscillation Stabilization Wait Time Timer of            | Timer Control Status Register (Lower) (TCCSL)                             |  |  |
| Subclock277                                             | 218                                                                       |  |  |
| Sub-clock Mode116                                       | Timer Control Status Register (Upper) (TCCSH)                             |  |  |
| Sub-clock Mode Transition Operating When                | 217                                                                       |  |  |
| Sub-clock Has Already Stopped 116                       | Timer Control Status Registers (High) (TMCSR:H)                           |  |  |
| Sub-clock Mode with External Single Clock Product       | 245                                                                       |  |  |
| 116                                                     | Timer Control Status Registers (Low) (TMCSR:L)                            |  |  |
| Symbols                                                 | 247                                                                       |  |  |
| Description of Instruction Presentation Items and       | Timer Data Register                                                       |  |  |
| symbols597                                              | Timer Data Register (TCDT)220                                             |  |  |
| Synchronization Methods                                 | Timer Register                                                            |  |  |
| Synchronization Methods                                 | Operating State of 16-bit Timer Register253                               |  |  |
| Synchronous Mode                                        | Timing                                                                    |  |  |
| Operation in Synchronous Mode (operation mode 2)        | RST and RY/BY Timing641                                                   |  |  |
|                                                         | RY/BY Timing during Writing/erasing641                                    |  |  |
|                                                         |                                                                           |  |  |
| System Configuration                                    | Timing Limit Exceeded Flag                                                |  |  |
| System Configuration and E <sup>2</sup> PROM Memory Map | Timing Limit Exceeded Flag (DQ5)543                                       |  |  |
| 517                                                     | TMCSR                                                                     |  |  |
| System Stack Pointer                                    | Timer Control Status Registers (High) (TMCSR:H)                           |  |  |
| User Stack Pointer (USP) and System Stack Pointer       | 245                                                                       |  |  |
| (SSP)41                                                 | Timer Control Status Registers (Low) (TMCSR:L)                            |  |  |
|                                                         | 247                                                                       |  |  |
| Т                                                       | TMR                                                                       |  |  |
| ТВТС                                                    | 16-bit Timer Registers (TMR)249                                           |  |  |
| Timebase Timer Control Register (TBTC) 185              | TMRLR                                                                     |  |  |
| TCCSH                                                   | 16-bit Reload Registers (TMRLR)250                                        |  |  |
|                                                         | Toggle Bit                                                                |  |  |
| Timer Control Starus Register (Upper) (TCCSH)           | Toggle Bit640                                                             |  |  |
|                                                         | Toggle Bit Flag                                                           |  |  |
| TCCSL                                                   | Toggle Bit Flag (DQ6)542                                                  |  |  |
| Timer Control Status Register (Lower) (TCCSL)           | Transition 12                                                             |  |  |
| 218                                                     | Clock Mode Transition103                                                  |  |  |
| TCDT                                                    | Notes on the Transition to Standby Mode157                                |  |  |
| Timer Data Register (TCDT)220                           | Sub-clock Mode Transition Operating When                                  |  |  |
| TDR                                                     | Sub-clock Hoad Transition Operating when Sub-clock Has Already Stopped116 |  |  |
| Transmission Data Register (TDR)400                     | Transition to Standby Mode157                                             |  |  |
| Temporary Sector Protect                                | •                                                                         |  |  |
| Temporary Sector Protect Cancellation 643               | Transmission                                                              |  |  |
| Timebase Timer                                          | Canceling Transmission Request from CAN                                   |  |  |
| Block Diagram of Timebase Timer                         | Controller                                                                |  |  |
| Correspondence between Timebase Timer                   | Procedure for Transmission by Message Buffer (x)                          |  |  |
| Interrupt and EI <sup>2</sup> OS187                     |                                                                           |  |  |
| Generation of Interrupt Request from Timebase Timer     | Starting Transmission of CAN Controller488                                |  |  |
| 184                                                     | Transmission Flowchart of CAN Controller489                               |  |  |
| Interrupt of Timebase Timer187                          | Transmission Data Register                                                |  |  |
| List of Registers and Reset Values of Timebase Timer    | Transmission Data Register (TDR)400                                       |  |  |
|                                                         | Transmission Interrupt                                                    |  |  |
| Precautions when Using Timebase Timer                   | Transmission Interrupt Generation and Flag Set                            |  |  |
| Program Example of Timebase Timer                       | Timing411                                                                 |  |  |
| Timebase Timer Control Register                         |                                                                           |  |  |
| Timebase Timer Control Register (TBTC) 185              | U                                                                         |  |  |
|                                                         |                                                                           |  |  |
| Timebase Timer Mode                                     | UART 207                                                                  |  |  |
| Return from Timebase Timer Mode                         | Block Diagram of LIN-UART                                                 |  |  |
| Switching to the Timebase Timer Mode                    | Block Diagram of LIN-UART Pins391                                         |  |  |

| LIN-UART as LIN Master Device439                  | W                                                              |
|---------------------------------------------------|----------------------------------------------------------------|
| LIN-UART Baud Rate Selection413                   | Watch Mode                                                     |
| LIN-UART Direct Pin Access432                     | Return from Watch Mode                                         |
| LIN-UART Functions382                             | Switching to the Watch Mode                                    |
| LIN-UART Interrupts406                            | _                                                              |
| LIN-UART Interrupts and EI <sup>2</sup> OS408     | Watch Timer                                                    |
| LIN-UART Pins391                                  | Block Diagram of Watch Timer                                   |
| LIN-UART Registers392                             | Generation of Interrupt Request from Watch Timer               |
| LIN-UART Serial Mode Register (SMR)395            | 272                                                            |
| Notes on Using LIN-UART441                        | List of Registers and Reset Values of Watch Timer              |
| Operation of LIN-UART420                          | 272                                                            |
| Undefined Instruction                             | Program Example of Watch Timer                                 |
| Exception Due to Execution of an Undefined        | Watch Timer Counter                                            |
| Instruction82                                     | Watch Timer Interrupt                                          |
| Execution of an Undefined Instruction82           | Watch Timer Interrupt and EI <sup>2</sup> OS Transfer Function |
| Underflow                                         | 275                                                            |
| Operation as 16-bit Timer Register Underflows     | Watch Timer Control Register                                   |
| 255, 260                                          | Watch Timer Control Register (WTC) 273                         |
| Operation at Underflow239                         | Watchdog Timer                                                 |
| _                                                 | Block Diagram of Watchdog Timer199                             |
| Use                                               | Functions of Watchdog Timer196                                 |
| Use of the "DIV A,Ri" and "DIVW A,RWi"            | List of Registers and Reset Values of Watchdog Timer           |
| Instructions without Precautions53                | 201                                                            |
| User Power Supply                                 | Operations of Watchdog Timer                                   |
| Example of Serial Programming Connection          | Precautions when Using Watchdog Timer 207                      |
| (User Power Supply Used)557                       | Program Examples of Watchdog Timer 208                         |
| User Stack Pointer                                | Setting Operation Clock of Watchdog Timer 277                  |
| User Stack Pointer (USP) and System Stack Pointer | Watchdog Timer Control Register                                |
| (SSP)41                                           | Watchdog Timer Control Register (WDTC) 202                     |
| USP                                               | WDTC                                                           |
| User Stack Pointer (USP) and System Stack Pointer |                                                                |
| (SSP)41                                           | Watchdog Timer Control Register (WDTC) 202                     |
| (44-)                                             | WE Control                                                     |
| V                                                 | Write,data Polling,read (WE control)                           |
| <b>Y</b>                                          | Writing to/erasing Flash Memory                                |
| Verify Sector Protect                             | Writing to/erasing Flash Memory 530                            |
| Enable Sector Protect/verify Sector Protect642    | WTC                                                            |
|                                                   | Watch Timer Control Register (WTC) 273                         |

CM44-10136-1E

## FUJITSU SEMICONDUCTOR • CONTROLLER MANUAL

F<sup>2</sup>MC<sup>TM</sup>-16LX 16-BIT MICROCONTROLLER MB90360 Series HARDWARE MANUAL

April 2005 the first edition

Published FUJITSU LIMITED Electronic Devices

Edited Business Promotion Dept.